问题
在Ubuntu安装MySQL时建议直接使用系统命令安装,如果使用官网下载安装包的方式非常复杂。
安装配置
1.安装
bash
sudo apt-get update
我在安装的时候这一步都出现问题,见了鬼了,排查后是因为网络问题,无法访问清华镜像导致的问题,后来通过更换阿里云镜像解决(阿里云镜像有点 慢,他们说科大的比较快)。如果这一步正常运行就不用管了。
##########################################################################
ps:如何更换镜像源
1.备份原来的源,将以前的源备份一下,以防以后可以用的。
bash
sudo cp /etc/apt/sources.list /etc/apt/sources.list.bak
2.打开/etc/apt/sources.list文件
bash
sudo vim /etc/apt/sources.list
3.清空文件内容,替换为下面内容(第一行你不要删)
bash
#添加阿里源
deb http://mirrors.aliyun.com/ubuntu/ focal main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ focal main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ focal-security main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ focal-security main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ focal-updates main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ focal-updates main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ focal-proposed main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ focal-proposed main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ focal-backports main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ focal-backports main restricted universe multiverse
3.更新
bash
sudo apt-get update
如出现依赖问题,解决方式如下:
bash
sudo apt-get -f install
####################################################################
然后使用如下命令安装
bash
sudo apt install mysql-server
完成后:
data:image/s3,"s3://crabby-images/bbf5e/bbf5e80401e5c0606c3e416cfd962c87c807b25a" alt=""
2.配置
1.查看MySQL状态
bash
sudo systemctl status mysql
data:image/s3,"s3://crabby-images/b2049/b20490a35fdc7d4d57286d8ac57a6c74740b7f3f" alt=""
2.配置密码
安装后的初始用户密码是随机的,需要查看一下再修改。
bash
sudo cat /etc/mysql/debian.cnf
data:image/s3,"s3://crabby-images/265ad/265adf92d08e6895d6c0c959d9377d7b959cacb9" alt=""
登录
bash
mysql -u debian-sys-maint -p
随后输入密码
data:image/s3,"s3://crabby-images/dfa8e/dfa8e465ea2a58acfc306e0e97549666886828b9" alt=""
成功进入
更改密码
bash
use mysql;
select user,plugin from user;
data:image/s3,"s3://crabby-images/7b668/7b668c55ead50348f8332e7bc52110b5bcb61105" alt=""
更改密码设置
bash
update user set plugin='mysql_native_password' where user ='root';
data:image/s3,"s3://crabby-images/6c09f/6c09fca8ec233eb63fcf37efce281d65e3ee20f1" alt=""
刷新配置
bash
flush privileges;
更改密码
bash
alter user 'root'@'localhost' identified by '1234';
data:image/s3,"s3://crabby-images/aea49/aea49360f6301362e6c3309d923fab5f3414c43b" alt=""
这一步可能会报错,如下
data:image/s3,"s3://crabby-images/c4174/c4174fc228f0397a938182e06b25068555e2455c" alt=""
这时要改一下密码策略
bash
set global validate_password.policy = 0;
set global validate_password.length = 4;
降低密码的校验规则之后,再次执行上述修改密码的指令。
退出
data:image/s3,"s3://crabby-images/14a7b/14a7bc53888b82ef7ad091e41afedb9aa689c5de" alt=""
重新登录
data:image/s3,"s3://crabby-images/9be32/9be3266dcb8ea3061326d5c4958143f1ac335968" alt=""
成功!
创建远程用户
默认的root用户只能当前节点localhost访问,是无法远程访问的,我们还需要创建一个root账户,用户远程访问
bash
create user 'root'@'%' IDENTIFIED WITH mysql_native_password BY '1234';
分配权限
bash
grant all on *.* to 'root'@'%';
然后就可以使用root用户通过任意ip远程连接了。