linux安装部署mysql服务 tar.gz rpm两种安装方式教程

这篇具有很好参考价值的文章主要介绍了linux安装部署mysql服务 tar.gz rpm两种安装方式教程。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一、介绍

本教程为linux下安装部署mysql服务,安装方式分为两种,一种tar.gz包安装,另一种为rpm包安装。

二、准备工作

服务器:linxu CentOS 7

mysql服务tar.gz版本:mysql-5.7.36-el7-x86_64.tar.gz

mysql服务rpm版本: mysql-5.7.36-1.el7.x86_64.rpm-bundler.tar

首先连接linux服务器,将防火墙关闭:


[root@128 ~]# systemctl stop firewalld
[root@128 ~]# systemctl disable firewalld

三、mysql服务tar.gz包安装

1.下载mysql-5.7.36-el7-x86_64.tar.gz安装包到/opt/目录下,并解压,重命名


[root@128 ~]# cd /opt
[root@128 opt]# wget https://cdn.mysql.com/archives/mysql-5.7/mysql-test-5.7.36-el7-x86_64.tar.gz
[root@128 opt]# tar -zxvf mysql-test-5.7.36-el7-x86_64.tar.gz
[root@128 opt]# mv mysql-test-5.7.36-el7-x86_64 mysql5.7

2.创建data、log目录,创建mysql.log、mysql.pid、mysql.sock文件,并创建mysql用户组并赋予mysql5.7目录权限


[root@128 opt]# cd mysql5.7
[root@128 mysql5.7]# mkdir data log
[root@128 mysql5.7]# cd log
[root@128 log]# touch mysql.log mysql.pid mysql.sock
[root@128 log]# cd ../../ 
[root@128 opt]# groupadd mysql
[root@128 opt]# useradd -r -g mysql mysql
[root@128 opt]# chown -R mysql:mysql mysql的根目录

目录结构如下:

linux安装部署mysql服务 tar.gz rpm两种安装方式教程

3.修改/etc/my.cnf配置文件,没有的话可自行创建,配置如下


[client]
#客户端连接端口
port=3306
#客户端连接sock
socket=/opt/mysql5.7/log/mysql.sock
#客户端编码
default-character-set=utf8
 
[mysqld]
#mysql服务端口
port=3306
#安装目录
basedir=/opt/mysql5.7
#数据存放目录
datadir=/opt/mysql5.7/data
#sock文件地址
socket=/opt/mysql5.7/log/mysql.sock
#错误日志存放地址
log-error=/opt/mysql5.7/log/mysql.log
#pid文件地址
pid-file=/opt/mysql5.7/log/mysql.pid
#服务端编码
character-set-server=utf8
 
!includedir /etc/my.cnf.d

4.初始化数据库,初始化完成后,初始密码再/opt/mysql5.7/log/mysql.log中存放


[root@128 opt]# cd mysql5.7
[root@128 mysql5.7]# bin/mysqld --initialize --user=mysql --basedir=/opt/mysql5.7 --datadir=/opt/mysql5.7/data
[root@128 mysql5.7]# cat log/mysql.log
linux安装部署mysql服务 tar.gz rpm两种安装方式教程

5.并启动mysql,并设置开机自启,修改初始化密码,赋予外部连接mysql权限


[root@128 mysql5.7]# cp support-files/mysql.server /etc/init.d/mysqld
#开机自启
[root@128 mysql5.7]# chkconfig --add mysqld   或者  systemctl enable mysqld
[root@128 mysql5.7]# systemctl start mysqld
[root@128 mysql5.7]# bin/mysql -uroot -p
Enter password:
mysql: [Warning] Using a password on the command line interface can be insecure.
......
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
 
mysql> set password=password("root");
mysql> grant all privileges on *.* to root@'%' identified by 'root' with grant option;
mysql> flush privileges;
mysql> exit;

6.使用navicat工具测试连接mysql。

linux安装部署mysql服务 tar.gz rpm两种安装方式教程

四、mysql服务rpm包安装

1.首先检查是否安装过mysql


[root@bogon mysql]# rpm -qa|grep mysql
[root@bogon mysql]# rpm -qa|grep mariadb
mariadb-libs-5.5.44-2.el7.centos.x86_64

2.如有安装mariadb,则卸载


[root@bogon mysql]# rpm -e --nodeps mariadb-libs-5.5.44-2.el7.centos.x86_64

3.下载mysql-5.7.36-1.el7.x86_64.rpm-bundler.tar安装包到/opt/目录下,创建mysql5.7目录,并解压


[root@bogon ~]# cd /opt
[root@bogon opt]# wget https://downloads.mysql.com/archives/get/p/23/file/mysql-5.7.36-1.el7.x86_64.rpm-bundle.tar
[root@bogon opt]# mkdir mysql5.7
[root@bogon opt]# tar -xvf mysql-5.7.36-1.el7.x86_64.rpm-bundle.tar -C /opt/mysql5.7/
[root@bogon opt]# cd mysql5.7
[root@bogon mysql5.7]# ll
总用量 533076
-rw-r--r--. 1 7155 31415  26664808 9月   8 2021 mysql-community-client-5.7.36-1.el7.x86_64.rpm
-rw-r--r--. 1 7155 31415    317808 9月   8 2021 mysql-community-common-5.7.36-1.el7.x86_64.rpm
-rw-r--r--. 1 7155 31415   4118740 9月   8 2021 mysql-community-devel-5.7.36-1.el7.x86_64.rpm
-rw-r--r--. 1 7155 31415  47760636 9月   8 2021 mysql-community-embedded-5.7.36-1.el7.x86_64.rpm
-rw-r--r--. 1 7155 31415  23316608 9月   8 2021 mysql-community-embedded-compat-5.7.36-1.el7.x86_64.rpm
-rw-r--r--. 1 7155 31415 132191192 9月   8 2021 mysql-community-embedded-devel-5.7.36-1.el7.x86_64.rpm
-rw-r--r--. 1 7155 31415   2473272 9月   8 2021 mysql-community-libs-5.7.36-1.el7.x86_64.rpm
-rw-r--r--. 1 7155 31415   1263988 9月   8 2021 mysql-community-libs-compat-5.7.36-1.el7.x86_64.rpm
-rw-r--r--. 1 7155 31415 182267476 9月   8 2021 mysql-community-server-5.7.36-1.el7.x86_64.rpm
-rw-r--r--. 1 7155 31415 125479900 9月   8 2021 mysql-community-test-5.7.36-1.el7.x86_64.rpm

4.安装按照common、libs、client、server顺序来,如出现下面错误,则安装perl


[root@bogon mysql5.7]# rpm -ivh mysql-community-common-5.7.36-1.el7.x86_64.rpm mysql-community-libs-5.7.36-1.el7.x86_64.rpm mysql-community-client-5.7.36-1.el7.x86_64.rpm mysql-community-server-5.7.36-1.el7.x86_64.rpm 
警告:mysql-community-common-5.7.36-1.el7.x86_64.rpm: 头V3 DSA/SHA256 Signature, 密钥 ID 5072e1f5: NOKEY
错误:依赖检测失败:
    /usr/bin/perl 被 mysql-community-server-5.7.36-1.el7.x86_64 需要
    perl(Getopt::Long) 被 mysql-community-server-5.7.36-1.el7.x86_64 需要
    perl(strict) 被 mysql-community-server-5.7.36-1.el7.x86_64 需要
[root@bogon mysql5.7]# yum -y install perl
[root@bogon mysql5.7]# rpm -ivh mysql-community-common-5.7.36-1.el7.x86_64.rpm mysql-community-libs-5.7.36-1.el7.x86_64.rpm mysql-community-client-5.7.36-1.el7.x86_64.rpm mysql-community-server-5.7.36-1.el7.x86_64.rpm
警告:mysql-community-common-5.7.36-1.el7.x86_64.rpm: 头V3 DSA/SHA256 Signature, 密钥 ID 5072e1f5: NOKEY
准备中...                          ################################# [100%]
正在升级/安装...
   1:mysql-community-common-5.7.36-1.e################################# [ 25%]
   2:mysql-community-libs-5.7.36-1.el7################################# [ 50%]
   3:mysql-community-client-5.7.36-1.e################################# [ 75%]
   4:mysql-community-server-5.7.36-1.e################################# [100%]

5.启动mysql,查询初始化密码为:qaw.d0N_%(je


[root@bogon mysql5.7]# systemctl start mysqld
[root@bogon mysql5.7]# grep password /var/log/mysqld.log 
2023-03-01T03:22:32.919615Z 1 [Note] A temporary password is generated for root@localhost: qaw.d0N_%(je

6.修改初始化密码,设置密码出现ERROR 1819 (HY000): Your password does not satisfy the current policy requirements提示,说明密码过于简单,可先设置复杂密码,然后查看密码规则


[root@bogon mysql5.7]# mysql -uroot -p
Enter password: qaw.d0N_%(je
mysql> set password = password("root");
ERROR 1819 (HY000): Your password does not satisfy the current policy requirements
mysql> set password=password('Abc123!@#');
Query OK, 0 rows affected, 1 warning (0.01 sec)
mysql> show variables like 'validate_password%';
+--------------------------------------+--------+
| Variable_name                        | Value  |
+--------------------------------------+--------+
| validate_password_check_user_name    | OFF    |
| validate_password_dictionary_file    |        |
| validate_password_length             | 8      |
| validate_password_mixed_case_count   | 1      |
| validate_password_number_count       | 1      |
| validate_password_policy             | MEDIUM |
| validate_password_special_char_count | 1      |
+--------------------------------------+--------+
7 rows in set (0.01 sec)

7.修改密码策略,重新设置密码,并开启允许远程连接数据库


#修改密码策略等级为低
mysql> set global validate_password_policy=LOW;
Query OK, 0 rows affected (0.00 sec)
#修改密码长度至少为4
mysql> set global validate_password_length=4;
Query OK, 0 rows affected (0.00 sec)
#重新设置密码
mysql> set password=password('root');
Query OK, 0 rows affected, 1 warning (0.00 sec)
#开启远程连接数据库
mysql> grant all privileges on *.* to root@'%' identified by 'root' with grant option;
Query OK, 0 rows affected, 1 warning (0.00 sec)
mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)

8.再其他电脑使用连接工具测试,连接成功

linux安装部署mysql服务 tar.gz rpm两种安装方式教程

9.设置编码字符集,修改/etc/my.cnf文件设置字符集


[root@bogon mysql5.7]# vi /etc/my.cnf
#添加如下编码配置
[mysqld]
character-set-server=utf8
[client]
default-character-set=utf8
[mysql]
default-character-set=utf8

10.重启mysql,并登录mysql查看字符集


[root@bogon mysql5.7]# systemctl restart mysqld
[root@bogon mysql5.7]# mysql -uroot -p
Enter password: root
mysql> show variables like '%character%';
+--------------------------+----------------------------+
| Variable_name            | Value                      |
+--------------------------+----------------------------+
| character_set_client     | utf8                       |
| character_set_connection | utf8                       |
| character_set_database   | utf8                       |
| character_set_filesystem | binary                     |
| character_set_results    | utf8                       |
| character_set_server     | utf8                       |
| character_set_system     | utf8                       |
| character_sets_dir       | /usr/share/mysql/charsets/ |
+--------------------------+----------------------------+
8 rows in set (0.00 sec)

五.修改mysql数据目录(有问题未解决)


#先关闭mysql
[root@bogon mysql5.7] systemctl stop mysqld
#创建新目录
[root@bogon mysql5.7] mkdir data
#将mysql数据目录整体复制到data目录
[root@bogon mysql5.7] cp -R /var/lib/mysql/* /opt/mysql5.7/data/
#备份原始数据文件
[root@bogon mysql5.7] mv /var/lib/mysql /var/lib/mysql_bak
#设置数据权限
[root@bogon mysql5.7] chown -R mysql:mysql data
[root@bogon mysql5.7] chmod -R 777 data

然后修改/etc/my.cnf文件修改目录


datadir=/opt/mysql5.7/data
socket=/opt/mysql5.7/data/mysql.sock

修改完成,启动mysql启动不起来,错误信息如下,有知道的欢迎留言

linux安装部署mysql服务 tar.gz rpm两种安装方式教程

/var/log/mysql.log日志如下:文章来源地址https://www.toymoban.com/news/detail-450136.html


2023-03-03T08:21:46.772613Z 0 [Note] InnoDB: Initializing buffer pool, total size = 128M, instances = 1, chunk size = 128M
2023-03-03T08:21:46.777358Z 0 [Note] InnoDB: Completed initialization of buffer pool
2023-03-03T08:21:46.778421Z 0 [Note] InnoDB: If the mysqld execution user is authorized, page cleaner thread priority can be changed. See the man page of setpriority().
2023-03-03T08:21:46.789316Z 0 [ERROR] InnoDB: The innodb_system data file 'ibdata1' must be writable
2023-03-03T08:21:46.789339Z 0 [ERROR] InnoDB: The innodb_system data file 'ibdata1' must be writable
2023-03-03T08:21:46.789344Z 0 [ERROR] InnoDB: Plugin initialization aborted with error Generic error
2023-03-03T08:21:47.393465Z 0 [ERROR] Plugin 'InnoDB' init function returned error.
2023-03-03T08:21:47.393543Z 0 [ERROR] Plugin 'InnoDB' registration as a STORAGE ENGINE failed.
2023-03-03T08:21:47.393557Z 0 [ERROR] Failed to initialize builtin plugins.
2023-03-03T08:21:47.393564Z 0 [ERROR] Aborting

2023-03-03T08:21:47.393650Z 0 [Note] Binlog end
2023-03-03T08:21:47.393816Z 0 [Note] Shutting down plugin 'CSV'
2023-03-03T08:21:47.394635Z 0 [Note] /usr/sbin/mysqld: Shutdown complete

到了这里,关于linux安装部署mysql服务 tar.gz rpm两种安装方式教程的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Linux - PostgreSQL 适用于9.x 以上的 tar.gz 源码安装与理解 - 报错集锦

    PostgreSQL 9.x 以下版本笔者没用过,具体操作看参考链接,笔者就不记录重复操作了,主要记录容易出问题的地方。 按照参考链接那样介绍,是在 ~/.bash_profile 文件配置 PGHOME 和 PGDATA 系统变量,但是每次重新登录命令行时, 总要手动激活 ~/.bash_profile 内的配置 ,否则 psql 命令

    2024年02月15日
    浏览(57)
  • linux 解压.tar.gz文件

    (1)解压 .tar.gz文件 其中, 文件名.tar.gz 是你要解压的文件的名称。 解释一下命令的选项: -z :表示使用 gzip 压缩算法进行解压。 -x :表示解压操作。 -v :可选参数,用于显示详细的解压过程。 例如,如果你有一个名为 archive.tar.gz 的文件,可以使用以下命令将其解压:

    2024年02月10日
    浏览(48)
  • linux解压tar.gz文件

    LINUX解压缩TAR.GZ文件命令 以下介绍如何压缩与解压 .tar.gz 格式的文件 1、压缩命令: 命令格式: 可先切换到当前目录下,压缩文件名和被压缩文件名都可加入路径。 2、解压缩命令: 命令格式:

    2024年02月12日
    浏览(43)
  • Linux命令解压多个tar.gz包

    命令行解压单个tar.gz包: tar zxvf package.tar.gz 命令行解压多个tar.gz包: for f in *.tar.gz; do tar zxvf \\\"$f\\\"; done 这个命令会循环遍历当前目录下的所有tar.gz包,然后逐个解压。 注:如果想要解压到指定的目录,可以加上 -C 参数,例如: tar zxvf package.tar.gz -C /path/to/destination

    2024年02月07日
    浏览(60)
  • CentOS 7.6使用mysql-8.0.31-1.el7.x86_64.rpm-bundle.tar安装Mysql 8.0

    https://downloads.mysql.com/archives/community/是社区版的官网,可以选择版本下载。 cat /etc/redhat-release 可以看到系统版本是 CentOS Linux release 7.6.1810 (Core) , uname -r 可以看到版本是 3.10.0-957.el7.x86_64 。 yum remove -y mysql-libs 把默认 mariadb 安装的一些组件卸载。 wget https://cdn.mysql.com/archives/m

    2024年02月07日
    浏览(66)
  • Linux 解压tar gz bz zip

    Linux系统中tar压缩包怎么解压?Linux系统中有一个tar压缩包格式的文件需要解压,但是linux系统中没有找到tar的命令,该怎么办呢?下面我们就来看看详细的教程,需要的朋友可以参考下 在Linux的默认的版本中不是所有的命令都有,但是基本的命令是都有的,但是有一下不常用

    2024年02月08日
    浏览(45)
  • Linux下 *.tar.gz文件解压缩命令

    Linux tar(英文全拼:tape archive )命令用于备份文件。 tar 是用来建立,还原备份文件的工具程序,它可以加入,解开备份文件内的文件。 gzip 是 GNU 组织开发的一个压缩程序,.gz 结尾的文件就是 gzip 压缩的结果。与 gzip 相对的解压程序是 gunzip。tar 中使用 -z 这个参数来调用

    2024年02月09日
    浏览(51)
  • Linux 解压tar.gz文件到指定目录

     如上例,/usr/local/src/下有一个tar包redis-6.2.5.tar.gz,要把它解压到 /tmp/redis/目录下。用-C选项参数就可以。注意,目标文件夹一定是要存在的,它不会自己创建不存在的文件夹。

    2024年02月12日
    浏览(61)
  • npm离线安装tar.gz

    npm是可以直接安装.tar.gz格式的包的, 这一点在私有软件包或者网络不可用的情况下会体现价值。 安装 卸载 .tar.gz 文件打包是需要多携带一层文件夹, 假设 abcd 这个包的name为abcd, 此时 .tar.gz 文件内部目录应该应该包含abcd这层文件夹, 如下: 如果缺少顶层的 abcd 目录, 会导致ins

    2024年02月16日
    浏览(46)
  • macos gz 方式安装 mysql8.1.0

    https://cdn.mysql.com//Downloads/MySQL-8.1/mysql-8.1.0-macos13-x86_64.tar.gz 解压 .tar.gz 文件,并将文件夹重命名为 mysql-8.1.0 用 mysql_config 配置环境变量 在 mysql-8.1.0 下创建 data 文件夹 初始化 data 文件夹 启动 server Navicat连接MySQL8.0亲测有效 - 无拘 - 博客园 https://dev.mysql.com/doc/refman/8.0/en/data-dir

    2024年02月16日
    浏览(41)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包