更新包列表
sudo apt update
安装mysql
sudo apt install mysql-server
启动mysql
// 启动mysql
sudo service mysql start// 关闭mysql
sudo service mysql stop// 重启mysql
sudo service mysql restart
连接mysql
// 初始安装无密码,直接连接即可,端口号默认3306
mysql -uroot
设置密码
ALTER USER 'root'@'localhost' IDENTIFIED BY '123456';
注:设置完密码后,后续如果使用 mysql -uroot -h127.0.0.1 -pkingsoft. -P3306(可使用 mysql -uroot -h localhost -pkingsoft. -P3306 命令代替)命令连接mysql时,可能会报错:
原因分析:
MySQL的 root 用户没有配置为允许从 127.0.0.1 这个地址连接。默认情况下,root 用户通常只能从 localhost 连接,而不是从 127.0.0.1。虽然 localhost 和 127.0.0.1 在很多情况下是等价的,但MySQL的权限系统会将它们视为不同的主机。
查看mysql root用户
SELECT User, Host FROM mysql.user WHERE User = 'root';
执行结果:
由上述查询结果可知,root 用户确实没有配置允许从 127.0.0.1 这个地址连接。
修改或创建用户权限
// 创建用户(如果尚未存在)
CREATE USER 'root'@'127.0.0.1' IDENTIFIED BY 'kingsoft.';// 授予权限
GRANT ALL PRIVILEGES ON *.* TO 'root'@'127.0.0.1' WITH GRANT OPTION;// 刷新权限,上述创建用户、授予权限操作只会被记录在mysql.user表中,需执行下述命令将其加载到缓存中方可生效
FLUSH PRIVILEGES;// 查看mysql root用户
SELECT User, Host FROM mysql.user WHERE User = 'root';
执行结果:
注1:如果不加127.0.0.1,则本地proxy无法连接到mysql。
注2:在 MySQL 5.7 及更高版本中,GRANT 语句和 IDENTIFIED BY 子句是分开的。您需要先创建用户(如果尚未存在),然后再授予权限。
注3:localhost、127.0.0.1仅限本机连接,如果想让公网上别的机器也能连接到mysql,需要把root用户的host字段改为‘%’,修改命令如下:
// 更新root用户host权限
update mysql.user set host='%' where user='root';
查看mysql读取my.cnf的顺序
// 如果不知道mysql使用的哪个配置文件,可以使用该命令查看mysql读取配置文件的顺序
mysqld --verbose --help | grep -A 1 'Default options'// 找到mysql使用的配置文件后,就可按自己需要对配置文件进行修改
// 修改后重启mysql即可
// 我的本地机器上没有 /etc/my.cnf 文件,所以修改 /etc/mysql/my.cnf
vim /etc/mysql/my.cnf
执行结果:
注:如果 /etc/my.cnf 文件存在,则优先使用该文件,如果 /etc/my.cnf 文件不存在,则使用 /etc/mysql/my.cnf 文件,以此类推。