- 升级常见问题
- 1. git pull 时提示 error: Your local changes to the following file would be overwritten by merge
- 2. sh make_migrations.sh 时提示 1064, “You have an error in your SQL syntax; check the manual than corresponds to your MySql server version for the right syntax to use near ‘(6) NOT NULL’”
- 3. 数据库表结构不完整导致升级失败的, 按如下内容进行处理
升级常见问题
请务必认真详细阅读每一个文字并理解后才能操作升级事宜
1. git pull 时提示 error: Your local changes to the following file would be overwritten by merge
# 这是因为你修改了本地文件导致代码冲突, 请确认修改的内容并手动进行合并, 请谨慎处理
# 如果希望保留你的改动
$ git stash
$ git pull
$ git stash pop
# 可以使用git diff -w +文件名 来确认代码自动合并的情况
# 或者放弃本地的修改
$ git reset --hard
$ git pull
2. sh make_migrations.sh 时提示 1064, “You have an error in your SQL syntax; check the manual than corresponds to your MySql server version for the right syntax to use near ‘(6) NOT NULL’”
# 这是因为你的数据库版本不对, 从 1.4.x 版本开始 mysql 版本需要大于等于 5.6, mariadb 版本需要大于等于 5.5.6
# 请更换数据库重新操作
3. 数据库表结构不完整导致升级失败的, 按如下内容进行处理
# 一定要知道自己升级之前的版本, 在升级之前可以通过如下代码进行查询, 记住是升级之前, 也可以通过 web 页面的右下角来查看当前版本信息
$ cat /opt/jumpserver/apps/jumpserver/context_processor.py | grep version
$ cat /opt/jumpserver/apps/templates/_footer.html | grep Version
# 备份当前版本数据库, 忽略 django_migrations 表
$ mysqldump -uroot -p jumpserver --ignore-table=jumpserver.django_migrations > /opt/jumpserver.sql
# 重命名 Jumpserver 目录
$ mv /opt/jumpserver /opt/jumpserver_bak
# 重新 clone 代码
$ cd /opt
$ git clone https://github.com/jumpserver/jumpserver.git
$ cd jumpserver
# 检出你之前的版本, 比如之前的版本是1.4.0
$ git checkout 1.4.0 # 1.4.0 表示版本号, 自己手动更换成你当前的版本, 如 1.3.1 则输入 git checkout 1.3.1
# 依赖安装
$ source /opt/py3/bin/activate
$ yum -y install $(cat /opt/jumpserver/requirements/rpm_requirements.txt)
$ pip install -r /opt/jumpserver/requirements/requirements.txt
# 重新创建一个数据库
$ mysql -uroot
> create database jumpserver01 default charset 'utf8';
> grant all on jumpserver01.* to 'jumpserver01'@'127.0.0.1' identified by 'weakPassword';
> flush privileges;
> quit
# 修改配置文件
$ cp /opt/jumpserver_bak/config.py /opt/jumpserver/
$ vim /opt/jumpserver/config.py
DB_ENGINE = 'mysql'
DB_HOST = '127.0.0.1'
DB_PORT = 3306
DB_USER = 'jumpserver01'
DB_PASSWORD = 'weakPassword'
DB_NAME = 'jumpserver01'
# 初始化数据库
$ cd /opt/jumpserver/utils
$ sh make_migrations.sh
# 确定初始化没有错误, 把旧的数据库导入
$ mysql -uroot
> use jumpserver01;
> source /opt/jumpserver.sql
# 启动 jumpserver, 确定没有错误
$ cd /opt/jumpserver
$ ./jms start
# 打开 web 页面检查是否都正常
$ 参考升级文档继续升级到最新版本即可
# 删除原数据库命令(谨慎操作)
$ mysql -uroot
> drop database jumpserver;
> quit