知了小站 - IT人的小站 - 2020年 https://www.ydyno.com/2020/ IT人的小站,分享开发经验,记录成长轨迹。 记 com.mysql.jdbc.PacketTooBigException 解决方案 https://www.ydyno.com/archives/1238.html 2020-09-14T16:03:00+08:00 解决方案一、修改配置文件可以通过更改 mysql 的配置文件 my.cnf 或者 my.ini 来更改这一默认值[mysqld] max_allowed_packet = 20M二、修改MySql依赖版本将 mysql-connector-java 版本修改为 5.1.45 即可 Typecho 迁移到 Docker 的过程记录 https://www.ydyno.com/archives/1237.html 2020-08-24T21:07:00+08:00 前言之前博客搭建在阿里云的机器上,现在快过期了,加上原机器带宽太小,就不打算续费了,现在就需要将 Typecho 博客迁移到新机器上。以前使用的是宝塔面板搭建的,现在不想把机器环境搞得乱七八糟,因此选择使用 Docker 来搭建 Typecho。安装Docker使用一键脚本安装Dockercurl -fsSL https://get.docker.com | bash -s docker --mirror Aliyun && systemctl start docker && systemctl enable docker如果提示 curl 命令不存在,就需要先安装 curl# Centos yum -y install curl # Ubuntu、Debian apt -y install curl配置镜像加速如果你机器是国内的机器,那么需要配置镜像加速阿里云镜像获取地址:https://cr.console.aliyun.com/cn-hangzhou/instances/mirrors修改 /etc/docker/daemon.json,文件不存在就创建一个{ "registry-mirrors": [ "你的加速地址" ] }安装数据库这里选择的是 Mariadb,可自行选择数据库镜像,这里配置参数就不做解释了,懂的都懂docker run -d -v /home/mysql:/var/lib/mysql \ -p 3306:3306 -e MYSQL_ROOT_PASSWORD=密码 \ --privileged=true --restart=always --name mariadb mariadb安装 PHP安装官方的 php:7.2-fpm 镜像后,还需要进入容器安装 mysql pdo 才能使用 Mysql 数据库,比较麻烦,这里我自己在 php:7.2-fpm 的基础上构建了个带 mysql pdo 的镜像,可以选择性使用。docker run -d -v /home/nginx/html:/var/www/html \ -p 8080:8080 --link mariadb:mariadb --name php dqjdda/php安装 Nginxdocker run -d \ --link php:php \ --name nginx --restart always \ -p 80:80 -p 443:443 \ -e "TZ=Asia/Shanghai" \ -v /home/nginx/nginx.conf:/etc/nginx/nginx.conf \ -v /home/nginx/conf.d:/etc/nginx/conf.d \ -v /home/nginx/logs:/var/log/nginx \ -v /home/nginx/cert:/etc/nginx/cert \ -v /home/nginx/html:/var/www/html \ nginx配置 Nginx/home/nginx/conf.d 用于放配置文件/home/nginx/logs 存放日志/home/nginx/cert 存放证书/home/nginx/html 存放网页在 /home/nginx/conf.d 目录创建文件 blog.confserver { listen 443 ssl http2; server_name www.ydyno.com; gzip on; # 缓存SSL ssl_session_cache shared:SSL:10m; ssl_session_timeout 1d; # 证书配置 ssl_certificate /etc/nginx/cert/ydyno.com/ydyno.com_chain.crt; ssl_certificate_key /etc/nginx/cert/ydyno.com/ydyno.com_key.key; root /var/www/html/ydyno; index index.php; # 伪静态 if (!-e $request_filename) { rewrite ^(.*)$ /index.php$1 last; } location ~ .*\.php(\/.*)*$ { include fastcgi_params; fastcgi_param PATH_INFO $fastcgi_path_info; fastcgi_param PATH_TRANSLATED $document_root$fastcgi_path_info; fastcgi_param SCRIPT_NAME $fastcgi_script_name; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; fastcgi_index index.php; fastcgi_pass php:9000; } location ~* \.(jpg|jpeg|gif|png|css|js|ico|xml)$ { expires 5d; } # deny access to . files, for security location ~ /\. { log_not_found off; deny all; } } server { listen 80; server_name www.ydyno.com ydyno.com; return 301 https://www.ydyno.com$request_uri; }迁移博客直接将老服务器的博客目录移动到 /var/www/html/ydyno ,然后将数据库导出,然后导入到新库即可 EL-ADMIN V2.5 版本发布,新增多项实用功能,代码多项优化 https://www.ydyno.com/archives/1234.html 2020-06-08T20:01:00+08:00 V2.4版本现基本稳定,V2.5版本都是基于现版本进行Bug修复与优化调整,新版本更新内容如下后端改动新增功能加入审计功能,继承 BaseEntity 后自动写入创建时间、修改时间、创建人、更新人,详见 AuditorConfigToken 自动续期功能,用户在快过期的时间内操作活跃,可将 Token 过期时间延长,详见 TokenFilter数据权限注解的实现,摈弃在 Controller 的操作方式,采用 @DataPermission 注解实现,详见 后端手册新的服务监控实现,后端采用 oshi,前端采用 echarts 做可视化借鉴了[宝塔监控],详见 预览地址定时任务创建时支持添加异常通知人,当定时任务执行失败发送邮件通知 [支持多邮箱], 详见 后端手册定时任务支持添加子任务,当主任务执行完后自动执行子任务 [支持多子任务,顺序执行], 详见 后端手册细节优化结构优化数据库脚本选择,见 脚本指南所有表按功能加入前缀:sys、tool、mnt 方便后续管理维护所有表字段的主键改为: 表名_id,方便与关联表的 id 统一所有表加入 create_by、update_by、create_time、update_time 字段,便于审计去除无用字段,加入必要索引加快查询速度,去除外键改为程序控制sys_user 表中加入 is_admin 字段用户区分是否为管理员删除 avatar 头像表,将头像的的头像名称与路径存入 sys_user 表代码优化去除首页 ip,pv 统计,此功能对于后台管理显得多余邮箱验证功能的验证码改为存储在 Redis 中,删除了原来从数据库中取的逻辑代码修改不规范的字段名/包名,将 mapper 包改为 mapstruct,避免与 mybatis 的 mapper 冲突重新设计缓存功能,去除不必要的缓存,去除监控模块,将新服务监控管理移入 system 模块用户管理、角色管理、菜单管理、部门管理中树形均采用懒加载方式实现,避免大量的数据导致页面卡顿加入RsaUtils工具类解决Hutool工具Rsa解密过慢的问题,IP 归属地查询改为用太平洋IP地址查询接口TokenFilter Token 验证逻辑优化,对于已放行的接口不去验证 Token 合法性文件上传优化,加入 FileProperties 配置,根据系统选择上传目录代码生成器前端 index.vue 模板查询优化,取消以前的下拉方式查询 详见错误修复运维管理解决不能向不同服务器部署应用的缺陷 #347运维管理解决部署到linux服务器路径拼接不正确问题 #347运维管理解决每次连接不同服务器都默认访问第一台服务器的问题 #347当前用户如果没有任何权限时,在输入用户名后,刷新验证码会抛IllegalArgumentException #333修复不存在账号登录时userService.findByName 抛出异常,loadUserByUsername未捕获处理的Bug 详见前端改动新增功能同一界面内,多CRUD共存,支持自定义数据id字段名 详见字典管理使用CRUD组件改写,CRUD组件增加对table延迟实例化支持,完善组件注册、注销 #83登录页背景使用本地图片,服务监控采用 v-echarts 实现用户管理、角色管理、菜单管理、部门管理,列表和弹窗数据懒加载用户头像裁剪上传节省空间 详见@crud/CRUD.operation中增加对列隐藏(初始阶段)支持 #95@crud/CRUD.operation中增加对列忽略支持 #95@crud/CRUD.operation中列可见性控制选项顺序跟随表格列顺序变更 #95细节优化优化主题切换按钮下移问题、优化tabs被footer遮挡问题、优化主题在页面刷新后重置的问题取消crud.props记录tableColumns,调整表格列可见性控制时插入位置计算 #95修改Token过期的提示,由原来的弹窗提示改为登录界面消息提示 详见错误修复修复V2.4版本中路由懒加载问题 详见修复菜单管理选择图标,backspace删除时不过滤数据 详见修复重定向到登录页,登录后参数丢失问题,比如文章详情/article?id=6 #94修复首页搜索菜单外链无法点击跳转问题 By RuoYi-Vue解决部署管理和数据库管理,选择记录不能启用自定义按钮的问题 详见修复字典管理模块点击编辑后再点击新增报错的问题 #366脚本指南项目根目录的 sql 文件夹内提供了本次数据库变更的脚本,脚本如何选择,以及执行的顺序如下操作数据库属于危险行为,请勿用于生产库,请事先做好备份!!!初次使用eladmin.sql 为 eladmin 项目完整的 sql 脚本,适合于初次使用的用户更新迭代对于老版本的,可以按下面的顺序执行删除所有外键.sql表名修改.sqlcode_ 相关表字段调整.sqlmnt_ 相关表字段调整.sqltool_ 相关表字段调整.sqlsys_ 相关表字段调整.sql用户岗位改动.sql相关数据更新.sql索引相关.sql删除无用表.sql脚本已经提供,其他的就需要自己慢慢调试了,祝成功!项目源码开发文档:https://el-admin.vip预览地址:https://el-admin.xin 后端源码前端源码Githubhttps://github.com/elunez/eladminhttps://github.com/elunez/eladmin-web码云https://gitee.com/elunez/eladminhttps://gitee.com/elunez/eladmin-web 快速解决 npm 安装 node-sass 速度慢/错误的问题 https://www.ydyno.com/archives/1219.html 2020-02-20T09:58:00+08:00 可通过配置淘宝的镜像源解决,首先配置淘宝的镜像源npm config set registry https://registry.npm.taobao.org然后在 ~/.npmrc 加入下面内容sass_binary_site=https://npm.taobao.org/mirrors/node-sass/.npmrc 文件位于win:C:\Users\[你的账户名称]\.npmrc linux:直接使用 vi ~/.npmrc完整配置如图 记一次 Centos 中因为 DNS npm 安装包失败的问题 https://www.ydyno.com/archives/1218.html 2020-02-18T17:02:00+08:00 在 centos 中使用 npm install 命令报错如下:09:13:56 npm WARN network SKIPPING OPTIONAL DEPENDENCY: request to https://registry.npm.taobao.org/nan failed, reason: getaddrinfo ENOTFOUND registry.npm.taobao.org registry.npm.taobao.org:443 09:13:56 npm WARN optional SKIPPING OPTIONAL DEPENDENCY: fsevents@1.2.4 (node_modules/fsevents): 09:13:56 npm WARN network SKIPPING OPTIONAL DEPENDENCY: request to https://registry.npm.taobao.org/fsevents failed, reason: getaddrinfo ENOTFOUND registry.npm.taobao.org registry.npm.taobao.org:443于是经过长达半个小时的搜索也没有找到答案,最后猜测是不是服务器网络或者host有问题试了下 ping www.baidu.com[root@localhost ~]# ping www.baidu.com ping: www.baidu.com: Name or service not known发现找不到百度的服务器,证明了这台服务器的host存在问题,于是定位到 /etc/resolv.conf 文件打开查看[root@localhost ~]# vi /etc/resolv.conf # Generated by NetworkManager nameserver fd20:25f7:e485::1添加下DNS到 resolv.conf 文件中nameserver 114.114.114.114保存文件,再次 ping www.baidu.com[root@localhost ~]# ping www.baidu.com PING www.a.shifen.com (14.215.177.38) 56(84) bytes of data. 64 bytes from 14.215.177.38 (14.215.177.38): icmp_seq=1 ttl=51 time=36.1 ms至此问题解决