0%

申请证书

下载下来的证书.pem格式可以直接修改成.crt格式.
私钥.key格式的文件.

更新harbor证书

服务器harbordocker-compose启动.

  1. 更新这个目录下证书文件
cat harbor.yml
# https related config
https:
#   # https port for harbor, default is 443
  port: 443
#   # The path of cert and key files for nginx
  certificate: /usr/local/bin/harbor/certs/harbor.crt
  private_key: /usr/local/bin/harbor/certs/harbor.key
  1. 找到harbornginx映射的cert目录,更新其中的证书.
cat docker-compose.yml 
proxy:
    image: goharbor/nginx-photon:v1.9.1
    container_name: nginx
    volumes:
      - ./common/config/nginx:/etc/nginx:z
      - /data/harbor/secret/cert:/etc/cert:z
    networks:
      - harbor
    dns_search: .
# ...
  1. 重启nginx
docker-compose restart proxy

流程图

流程图

  • 网页端生成随机code,携带code去请求一张二维码图片;
  • 网页端轮询code是否登录成功状态;
  • APP端扫描二维码,获取二维码内容;
  • APP端验证二维码是否过期/无效;
  • 如果二维码有效,展示确认登录/取消按钮;
  • APP端携带登录信息token确认登陆;
  • 后端为code绑定登录信息(token,userName),网页端轮询获得登录成功信息.

查看mysql是否开启定时任务

mysql> show variables like '%scheduler%';
+-----------------+-------+
| Variable_name   | Value |
+-----------------+-------+
| event_scheduler | OFF   |
+-----------------+-------+
1 row in set

开启mysql定时任务

-- 临时开启
SET GLOBAL event_scheduler = ON;

-- 永久开启,my.cnf中[mysqld]添加,并重启服务
event_scheduler=on

删除某表2天前的数据SQL

-- task_history:表名,start_time:日期字段
delete From task_history where DATE(start_time) <= DATE(DATE_SUB(NOW(),INTERVAL 2 day));

创建event

  • 方法一:直接创建删除数据event
create event del_task_history on SCHEDULE every 1 DAY do delete from compare.task_history where DATE(start_time) <= DATE(DATE_SUB(NOW(),INTERVAL 2 day));
  • 方法二:先创建删除数据的存储过程
-- 创建存储过程,先use database_name;
DELIMITER // 
create procedure del_task_history()
BEGIN
    DELETE FROM task_history WHERE DATE(start_time) <= DATE(DATE_SUB(NOW(),INTERVAL 2 day));
END//
DELIMITER ;
-- 查看存储过程
select * from mysql.proc where db='数据库名';
-- 调用存储过程
call del_task_history();
-- 删除存储过程
DROP PROCEDURE IF EXISTS del_task_history;


-- 创建event
create event del_task_history  
on schedule 
EVERY 1 DAY  
STARTS '2020-10-01 00:00:00'  
ON COMPLETION NOT PRESERVE ENABLE DO CALL del_task_history();

开启和关闭event

--  开启某事件
ALTER EVENT del_task_history ON COMPLETION PRESERVE ENABLE;
--  关闭某事件
ALTER EVENT del_task_history ON COMPLETION PRESERVE DISABLE;

查询event

-- 查询event列表
show events;
-- 根据event名称查询
show create event del_task_history;

-- 查询执行记录
select * from information_schema.events;
select * from mysql.event;

删除event

DROP EVENT IF EXISTS del_task_history;

写一个带参数的存储过程

存储过程一般不能以表名作为参数,不然会报错,所以采用prepare方式.

  • prepare: 预处理
  • execute: 执行
  • deallocate: 释放资源
-- 参数1:要删除的表, 参数2:时间戳列名, 参数3:删除多少天前的数据
DELIMITER // 
create procedure delete_table_data(IN table_name varchar(50),IN column_name varchar(50),IN interval_day int)
BEGIN
    set @statements = concat('DELETE FROM ',table_name, ' WHERE DATE(',column_name,') <= DATE(DATE_SUB(NOW(),INTERVAL ',interval_day,' day))');
    prepare stmt from @statements;
    execute stmt;
    deallocate prepare stmt;
END//
DELIMITER ;

-- 调用
call delete_table_data('t_test','create_time',90);

问题

docker安装完成后,默认只能root用户才能使用docker命令.

解决

# 创建用户组,默认安装docker可能已经创建了
groupadd docker

# 将当前用户加入到docker组
usermod -aG docker $USER
# 示例
usermod -aG docker hadoop

# 重新登录即可使用docker命令

问题描述

在windows上使用ftp上传文件到Linux上,中文名称在Linux系统中显示为乱码。

原因在于,Windows 的文件名中文编码默认为GBK,压缩或者上传后,文件名还会是GBK编码,而Linux中默认文件名编码为UTF8,由于编码不一致所以导致了文件名乱码的问题,解决这个问题需要对文件名进行转码。

问题解决

# 安装
yum install convmv 
# 转换
convmv -f gbk -t utf-8 -r --notest /home/test

HttpServletRequest和@Async搭配使用问题

问题描述:希望将request中参数传递到service中处理,同时service是使用异步@Async,此时通过request.getParameterMap()获取参数列表只能在程序启动第一次才能获取到,第二次及之后获取为空,测试如果去掉@Async注解则每次都能获取到参数.

// Controller层
@GetMapping("/call")
public String callback(HttpServletRequest request) {
    // 这是一个异步方法
    service.call(request.getParameterMap());
    return "ok";
}
// Service层
@Async
public String call(Map<String, String[]>extras) {
    //todo 
    // 对extras做处理
    return "ok";
}

问题解决

// Controller层
@GetMapping("/call")
public String callback(HttpServletRequest request) {
    // 需要创建一个新的map,将request中参数导入,再传递到异步方法中
    Map<String, String[]> extras = new HashMap<>();
    extras.putAll(request.getParameterMap());
    service.call(extras);
    return "ok";
}

原因分析

  • request.getParameterMap()返回的是一个Map类型的值,该返回值记录着前端所提交请求中的请求参数和请求参数值的映射关系。这个返回值有个特别之处——只能读。不像普通的Map类型数据一样可以修改。这是因为服务器为了实现一定的安全规范,所作的限制。

  • 如果实在有必要在取得此值以后做修改的话,要新建一个map对象,将返回值复制到此新map对象中进行修改,用新的map对象代替使用之前的返回值。

  • 源码分析

// Collections.unmodifiableMap()方法使得集合为只读。
public Map getParameterMap() {
    Map result = new HashMap();
    if (!this.paramsSnapshot.isEmpty()) {
        result.putAll(this.paramsSnapshot);
    }
    result.putAll(super.getParameterMap());
    return Collections.unmodifiableMap(result);
}