linux安装mysql服务

本文详细介绍了在Linux上安装MySQL8.0的步骤,包括下载二进制包,安装依赖如libaio和numactl,解压并移动到/usr/local,创建用户和权限,初始化数据库,设置SSL,以及启动服务和修改root用户的密码。文章提供了两种修改root密码的方法,并强调了安全性。
摘要由CSDN通过智能技术生成

一、环境

继Mysql5.7之后,mysql直接升级到了8.0,据传闻是查询效率提升了2倍,因此本次我也尝试使用8.0版本mysql进行安装

二、安装过程

2.1 下载安装包 

Mysql下载安装包地址:MySQL :: Download MySQL Community Server 

选择的是Lunx 64位通用的二进制版本,这样不再需要进行编译安装,系统安装依赖库就可以直接使用 

2.2 安装依赖库

官方说要安装libaio,但实际你还需要安装numactl库

apt install numactl

apt install libaio-dev

apt install numactl
apt install libaio-dev

2.3 解压软件包到系统

解压之后将软件移动到系统中的/usr/local目录,并且命名为mysql

tar -zxvf mysql-8.0.11-linux-glibc2.12-x86_64.tar.gz

mv mysql-8.0.11-linux-glibc2.12-x86_64 /usr/local/mysql

tar -zxvf mysql-8.0.11-linux-glibc2.12-x86_64.tar.gz
mv mysql-8.0.11-linux-glibc2.12-x86_64 /usr/local/mysql

2.4 添加用户、设置权限

groupadd mysql

useradd -r -g mysql -s /bin /false mysql

cd /usr/local

cd mysql

mkdir mysql-files

chown mysql:mysql mysql-files

chmod 750 mysql-files

roupadd mysql
useradd -r -g mysql -s /bin/false mysql
cd /usr/local
cd mysql
mkdir mysql-files
chown mysql:mysql mysql-files
chmod 750 mysql-files

2.5 初始化数据库

bin/mysqld --initialize --user=mysql

bin/mysqld --initialize --user=mysql

可以看到系统随机给root用户分配了一个密码,这个密码要记住

2.6 安装ssl服务

执行安装命令之前先安装openssl,不然会报错

apt install openssl

bin/mysql_ssl_rsa_setup

apt install openssl
bin/mysql_ssl_rsa_setup

2.7 复制服务文件

cp support-files/mysql.server /etc/init.d/mysql.server

cp support-files/mysql.server /etc/init.d/mysql.server

三 使用mysql 8.0

3.1 开启服务

&代表后台运行,执行命令之后,终端会开在一个位置,按一下enter键即可

bin/mysqld_safe --user=mysql &

bin/mysqld_safe --user=mysql &

3.2 使用用户root登陆

bin/mysql -uroot -p

bin/mysql -uroot -p

3.3 更改用户密码

第一次登陆之后需要修改密码

(1)方案一:修改本地密码

ALTER USER 'root'@'localhost' IDENTIFIED BY '新密码';
flush privileges;

ALTER USER 'root'@'localhost' IDENTIFIED BY '新密码';

flush privileges;

(2)方案二:修改密码,并且设置为任意ip允许第三方客户端登陆

# 修改root的密码与加密方式
ALTER USER 'root'@'localhost' IDENTIFIED BY '密码' PASSWORD EXPIRE NEVER;
# 切换到mysql库
use mysql;
# 更改可以登录的IP为任意IP
update user set host='%' where user = 'root';
# 刷新权限
flush privileges;
# 再次更改root用户密码,使其可以在任意IP访问
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '密码';
# 刷新权限
flush privileges;

# 修改root密码与加密方式

ALTER USER 'root'@'localhost' IDENTIFIED BY '密码' PASSWORD EXPIRD NEVER;

#切换到mysql库

use mysql;

# 更改可以登陆的IP为任意IP

update user set host='%' where user = 'root';

#刷新权限

flush privileges;

#再次更改root密码,使其可以在任意ip访问

ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '密码';

#刷新权限

flush privileges;

感谢观看!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
LINUX重启MYSQL的命令 . 分类: Linux 2010-06-25 10:21 6367人阅读 评论(0) 收藏 举报 如何启动/停止/重启MySQL 一、启动方式 1、使用 service 启动:service mysqld start 2、使用 mysqld 脚本启动:/etc/inint.d/mysqld start 3、使用 safe_mysqld 启动:safe_mysqld& 二、停止 1、使用 service 启动:service mysqld stop 2、使用 mysqld 脚本启动:/etc/inint.d/mysqld stop 3、 mysqladmin shutdown 三、重启 1、使用 service 启动:service mysqld restart 2、使用 mysqld 脚本启动:/etc/inint.d/mysqld restart 提问 编辑摘要 如何启动/停止/重启MySQL 一、启动方式 1、使用 service 启动:service mysqld start 2、使用 mysqld 脚本启动:/etc/inint.d/mysqld start 3、使用 safe_mysqld 启动:safe_mysqld& 二、停止 1、使用 service 启动:service mysqld stop 2、使用 mysqld 脚本启动:/etc/inint.d/mysqld stop 3、 mysqladmin shutdown 三、重启 1、使用 service 启动:service mysqld restart 2、使用 mysqld 脚本启动:/etc/inint.d/mysqld restart 刚开始学 mysql时都是用redhat自带的。启动是什么 /rc.d/init.d/ start 这很简单,但是后来越学越多,系统自带的 mysql,有的是版本太低,有的是与 自己想要装的web服务需要的低版本的mysql 后来自己学着以tar的方式安装 mysql,我的mysql装在/usr/local/mysql目录下启 动碰到过很多问题。最常见的是: ERROR 2002: Can't connect to local MySQL server through socket '/tmp/mysql.sock' (111) 解决办法: [root@test mysql]# /usr/local/mysql/bin/mysqladmin -u root / > -S /var/lib/mysql/mysql.sock password 'your.passwd' 或者做个连接 ln -s /var/lib/mysql/mysql.sock /tmp 其实提示找不到 /tmp/mysql.sock有时也并不是/tmp目录下没这个文件,是启动 命令不对,我碰到过 常见的几种启动方式,自己也不是记得很清楚,如果你确定tmp下有mysql.sock这 个文件不妨试试另外的几个命令 /usr/local/mysql/bin/mysql -u root -p /usr/local/mysql/bin/mysqld --user=mysql& /usr/local/mysql/bin/mysqld --user=root& /usr/local/mysql/bin/mysqld_safe --user=root& /usr/local/mysql/bin/mysqld_safe --user=mysql& /usr/local/mysql/bin/safe_mysqld--uer=root&(注意 safe_mysqld与mysqld_safe是不同的,&表示mysql在后台运行)我的就会报错了 STOPPING server from pid file /usr/local/mysql/data/localhost.localdomain.pid 060304 11:46:21 mysqld ended 这是权限问题,我的mysql目录属于root用户,也属于root群组,改用 mysqld_safe启动就没问题了, 大家只要注意这几个 mysql,safe_mysqld,mysqld_safe,mysqld,mysqladmin.多试 几次 其实有时mysql已经正常启动了,查看mysql是否启动命令 ps -aux | grep mysqld 会看到如下类似内容 mysql 6394 0.0 1.5 10528 992 pts/3 S 16:16 0:00 /usr/local/mysql/ mysql 6395 0.0 1.5 10528 992 pts/3 S 16:16 0:00 /usr/local/mysql/ mysql 6396 0.0 1.5 10528 992 pts/3 S 16:16 0:00 /usr/local/mysql/ root 6422 0.0 1.1 2408 732 pts/3 S 16:20 0:00 grep mysql 查看mysql是否在监听端口命令 netstat -tl | grep mysql 会看到如下类似内容 tcp 0 0 *:mysql *:* LISTEN
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值