翼度科技»论坛 编程开发 mysql 查看内容

Mysql8.4.3LTS中离线部署的实现示例

9

主题

9

帖子

27

积分

新手上路

Rank: 1

积分
27
一、部署环境

软件:
  1. mysql8.4.3LTS
复制代码
系统:
  1. ubuntu24.04
复制代码

资源配置
  1. 资源分配的大小与业务系统的体量有关系;所以没有固定
复制代码
CPU: 2核
内存: 4 GB
磁盘: 50 GB sda[系统盘] 50GB, 默认分区
sdc[数据盘] 100GB 挂载点 /dcdata

二、下载地址

MySQL :: Download MySQL Community Server


版本选择

由于我的操作系统比较新, 通过
  1. ldd --version
复制代码
命令查看glibc版本为2.39,所以选择了 glibc 2.28的版本
**注:**如果操作系统支持的话还是选择新的;但是考虑兼容性和维护性,我个人的部署脚本中目前选择的还是glibc2.17的包;
演示使用的是glibc2.28版本的包,后续我也将这个版本的Mysql部署到开发和测试环境中使用,组员一起体验他的稳定性和性能。

三、部署详情


1. 上传安装包

将安装包上传到服务器中,使用root用户安装,上传路径
  1. /root/mysql-8.4.3-linux-glibc2.28-x86_64.tar.xz
复制代码


2. 解压软件包

安装包上传后,执行解压到/dcsm目录下
  1. # 新建dcsm文件夹
  2. mkdir /dcsm
  3. tar -xvf /root/mysql-8.4.3-linux-glibc2.28-x86_64.tar.xz -C /dcsm
  4. cd /dcsm && mv mysql-8.4.3-linux-glibc2.28-x86_64/ mysql
复制代码
3. 安装mysql

3.3.1 创建mysql用户与用户组
查询系统中是否存在mysql用户
  1. cat /etc/passwd | cut -f1 -d':' | grep -w "mysql" -c

  2. groupadd mysql && useradd -r -g mysql -s /bin/false mysql
复制代码

3.3.2 授权安装文件夹
  1. # 创建相关文件夹
  2. mkdir -p /dcdata/mysql/log && mkdir -p /dcdata/mysql/data && mkdir -p /dcdata/mysql/run && mkdir -p /dcdata/mysql/lib

  3. # 授权
  4. chown -R mysql:mysql /dcsm/mysql && chown -R mysql:mysql /dcdata/mysql
复制代码

3.3.3 安装libaio依赖 (坑)
这个依赖是和你操作系统版本有关系的;

ubuntu24.04 中关于libaio的坑

该系统在安装后自带libaio

虽然
  1. whereis
复制代码
搜不到
  1. libaio.so.1
复制代码
这个文件; 但系统中确实安装了 libaio;
这也是我后续初始化依然报错的原因;解决办法就是建立超链接,让mysql在初始化的时候找到这个命令
  1. ln -s /lib/x86_64-linux-gnu/libaio.so.1t64 /lib/x86_64-linux-gnu/libaio.so.1
复制代码

这里介绍查找方法;
找一台和你镜像一样,或者操作系统版本一样的可以联网的机器;
  1. apt search libaio
复制代码

  1. /var/cache/apt/archives/
复制代码
下找到这个离线deb包; 在离线环境下就可以直接
  1. dpkg -i 
复制代码
安装这个依赖包了
注:如果不安装此依赖,后续初始化mysql数据库时会提示缺少此依赖,官网教程中也特意提到要安装这个依赖。
3.3.4 初始化Mysql数据库
  1. cd /dcsm/mysql

  2. # 初始化
  3. bin/mysqld --initialize --user=mysql --basedir=/dcsm/mysql --datadir=/dcdata/mysql/data --log-error=/dcdata/mysql/log/mysqld.log
复制代码

注:这是ubuntu24.04 上的坑。系统的 libaio.so.1 软连接的地址不存在;
解决方法就是重新建立一个软链接
  1. ln -s /lib/x86_64-linux-gnu/libaio.so.1t64 /lib/x86_64-linux-gnu/libaio.so.1
复制代码
3.3.5 编辑my.cnf
  1. /etc/my.cnf
复制代码
  1. [mysqld]
  2. # cache in MySQL. Start at 70% of total RAM for dedicated server, else 10%.
  3. #innodb_buffer_pool_size = 128M
  4. # join_buffer_size = 128M
  5. # sort_buffer_size = 2M
  6. # read_rnd_buffer_size = 2M
  7. basedir=/dcsm/mysql
  8. datadir=/dcdata/mysql/data
  9. socket=/dcdata/mysql/lib/mysql.sock
  10. port=3306
  11. log-error=/dcdata/mysql/log/mysqld.log
  12. pid-file=/dcdata/mysql/run/mysqld.pid

  13. # 开启远程,类似dblink
  14. federated
  15. log_bin_trust_function_creators=1
  16. # 时间跟随本地
  17. log_timestamps=system
  18. # 允许最大连接数
  19. max_connections=2000
  20. # 关闭binlog日志
  21. skip-log-bin

  22. [mysql]
  23. socket=/dcdata/mysql/lib/mysql.sock
复制代码
3.3.6 配置环境变量
  1. ### 添加到系统服务中
  2. cp /dcsm/mysql/support-files/mysql.server /etc/init.d/mysql  && chmod +x /etc/init.d/mysql

  3. ### 配置到环境变量中
  4. echo "/dcsm/mysql/lib" >>/etc/ld.so.conf &&
  5. echo "#MYSQL ENVIRONMENT" >>/etc/profile &&
  6. echo "export PATH=/dcsm/mysql/bin:/dcsm/mysql/lib:\$PATH" >>/etc/profile &&
  7. source /etc/profile
复制代码
3.3.7 启动mysql
  1. ### 重新加载systemd的配置信息
  2. systemctl daemon-reload
  3. systemctl start mysql
复制代码

设置开机启动
  1. systemctl enable mysql
复制代码
3.3.8 登录mysql
获取初始化密码
  1. grep 'temporary password' /dcdata/mysql/log/mysqld.log | awk '{print $NF}'
复制代码

3.3.8.1 创建root
创建mysql账号root,并设置密码
  1. mysql --connect-expired-password -uroot -p
复制代码
然后输入上述密码;
连上mysql后,修改root密码,
  1. ALTER USER ‘root'@‘localhost' IDENTIFIED WITH mysql_native_password BY ‘MyNewPass';
复制代码

原因参考:[MySQL8.0.34 开始被弃用mysql_native_password插件](https://dev.mysql.com/doc/refman/8.4/en/native-pluggable-authentication.html#:~:text=MySQL client programs in MySQL 8.4 (and later),what is desired%2C like this%3A %24> mysql --default-auth%3Dmysql_native_password)
3.3.8.2 Plugin ‘mysql_native_password’ is not load 两种解决办法
重新启动该插件(不推荐)
具体做法就是修改my.cnf 文件

重启mysql,即可生效;
使用官方推荐方式
  1. ALTER USER 'root'@'localhost' IDENTIFIED BY 'new_password';
复制代码
3.3.8.3 授权
  1. use mysql; update user set host = '%' where user ='root'; flush privileges;
复制代码
至此部署完成~

四、快速部署脚本

该脚本适用于快速部署使用,请注意安装包版本与系统版本;
我用的是ubuntu24.04, mysql8.4.3tls
vim deploy_mysql.sh
  1. #!/bin/bash

  2. ### 假设安装包已上传到/root下

  3. ### 解压软件包
  4. mkdir /dcsm
  5. tar -xvf /root/mysql-8.4.3-linux-glibc2.28-x86_64.tar.xz -C /dcsm
  6. cd /dcsm && mv mysql-8.4.3-linux-glibc2.28-x86_64/ mysql

  7. ### 创建 mysql 用户与用户组
  8. if [ $(cat /etc/passwd | cut -f1 -d':' | grep -w "mysql" -c) -eq 0 ]; then
  9.     groupadd mysql && useradd -r -g mysql -s /bin/false mysql
  10. fi

  11. ### 授权安装文件夹
  12. mkdir -p /dcdata/mysql/log && mkdir -p /dcdata/mysql/data && mkdir -p /dcdata/mysql/run && mkdir -p /dcdata/mysql/lib
  13. chown -R mysql:mysql /dcsm/mysql && chown -R mysql:mysql /dcdata/mysql

  14. ### 建立软链接
  15. ln -s /lib/x86_64-linux-gnu/libaio.so.1t64 /lib/x86_64-linux-gnu/libaio.so.1

  16. ### 初始化 Mysql
  17. cd /dcsm/mysql

  18. bin/mysqld --initialize --user=mysql --basedir=/dcsm/mysql --datadir=/dcdata/mysql/data --log-error=/dcdata/mysql/log/mysqld.log

  19. # 3.3.5 编辑 my.cnf
  20. cat <<EOF > /etc/my.cnf
  21. [mysqld]
  22. # cache in MySQL. Start at 70% of total RAM for dedicated server, else 10%.
  23. #innodb_buffer_pool_size = 128M
  24. # join_buffer_size = 128M
  25. # sort_buffer_size = 2M
  26. # read_rnd_buffer_size = 2M
  27. basedir=/dcsm/mysql
  28. datadir=/dcdata/mysql/data
  29. socket=/dcdata/mysql/lib/mysql.sock
  30. port=3306
  31. log-error=/dcdata/mysql/log/mysqld.log
  32. pid-file=/dcdata/mysql/run/mysqld.pid

  33. # 开启远程,类似 dblink
  34. federated
  35. log_bin_trust_function_creators=1
  36. # 时间跟随本地
  37. log_timestamps=system
  38. # 允许最大连接数
  39. max_connections=2000
  40. # 关闭 binlog 日志
  41. skip-log-bin

  42. [mysql]
  43. socket=/dcdata/mysql/lib/mysql.sock
  44. EOF

  45. ### 配置环境变量
  46. cp /dcsm/mysql/support-files/mysql.server /etc/init.d/mysql && chmod +x /etc/init.d/mysql
  47. echo "/dcsm/mysql/lib" >>/etc/ld.so.conf
  48. echo "#MYSQL ENVIRONMENT" >>/etc/profile
  49. echo "export PATH=/dcsm/mysql/bin:/dcsm/mysql/lib:\$PATH" >>/etc/profile
  50. source /etc/profile

  51. ### 启动 mysql
  52. systemctl daemon-reload
  53. systemctl start mysql
  54. systemctl enable mysql

  55. ### mysql修改密码 并允许远程
  56. initial_password=$(grep 'temporary password' /dcdata/mysql/log/mysqld.log | awk '{print $NF}')
  57. mysql --connect-expired-password -uroot -p"$initial_password" <<EOF
  58. ALTER USER 'root'@'localhost' IDENTIFIED BY 'new_password';
  59. use mysql; update user set host = '%' where user ='root'; flush privileges;
  60. EOF

  61. source /etc/profile
复制代码
脚本授权
  1. chmod +x deploy_mysql.sh
复制代码
执行部署
  1. ./deploy_mysql.sh
复制代码

连接成功;

到此这篇关于Mysql8.4.3LTS中离线部署的实现示例的文章就介绍到这了,更多相关Mysql8.4.3LTS 离线部署内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

来源:https://www.jb51.net/database/330753x42.htm
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x

举报 回复