文章目录

  • Ubuntu18.04 安装MySQL
  • 1.安装MySQL
  • 2.配置MySQL
  • 2.1 初始化配置
  • 2.2 检查mysql服务状态
  • 3.配置远程访问
  • 3.1 首先用根用户进入
  • 3.2 新建数据库和用户
  • 3.3 创建远程访问用户及数据
  • ubuntu完全卸载mysql


Ubuntu18.04 安装MySQL

环境信息:
OS:Ubuntu18.04
MySQL: 5.7.22

1.安装MySQL

在Ubuntu中,默认情况下,只有最新版本的MySQL包含在APT软件包存储库中,要安装它,只需更新服务器上的包索引并安装默认包apt-get。

#命令1
sudo apt-get update
#命令2
sudo apt-get install mysql-server
2.配置MySQL
2.1 初始化配置
sudo mysql_secure_installation
Securing the MySQL server deployment.

Connecting to MySQL using a blank password.

VALIDATE PASSWORD PLUGIN can be used to test passwords
and improve security. It checks the strength of password
and allows the users to set only those passwords which are
secure enough. Would you like to setup VALIDATE PASSWORD plugin?

Press y|Y for Yes, any other key for No: 

#1
VALIDATE PASSWORD PLUGIN can be used to test passwords...
Press y|Y for Yes, any other key for No: N (我的选项)

#2
Please set the password for root here...
New password: (输入密码)
Re-enter new password: (重复输入)

#3
By default, a MySQL installation has an anonymous user,
allowing anyone to log into MySQL without having to have
a user account created for them...
Remove anonymous users? (Press y|Y for Yes, any other key for No) : N (我的选项)

#4
Normally, root should only be allowed to connect from
'localhost'. This ensures that someone cannot guess at
the root password from the network...
Disallow root login remotely? (Press y|Y for Yes, any other key for No) : Y (我的选项)

#5
By default, MySQL comes with a database named 'test' that
anyone can access...
Remove test database and access to it? (Press y|Y for Yes, any other key for No) : N (我的选项)

#6
Reloading the privilege tables will ensure that all changes
made so far will take effect immediately.
Reload privilege tables now? (Press y|Y for Yes, any other key for No) : Y (我的选项)
2.2 检查mysql服务状态
systemctl status mysql.service
3.配置远程访问

在Ubuntu下MySQL缺省是只允许本地访问的,使用NAVICAT连接工具是连不上的;
如果你要其他机器也能够访问的话,需要进行配置;

3.1 首先用根用户进入
sudo mysql -uroot -p

登入root进行其他设置:

# 设置本地访问
GRANT ALL PRIVILEGES ON *.* TO root@localhost IDENTIFIED BY "123456";
# 设置任何用户都能访问
GRANT ALL PRIVILEGES ON *.* TO root@% IDENTIFIED BY "123456";

ubuntu mysql数据文件 ubuntu自带数据库_mysql

其中root@localhos,localhost就是本地访问,配置成%就是所有主机都可连接;

第二个’123456’为你给新增权限用户设置的密码,% 代表所有主机,也可以是具体的ip;
不过这随设置了%但我root通过工具还是登陆不进去,可能是为了安全性,所以新建数据库和用户;

3.2 新建数据库和用户

用root用户新建数据和用作远程访问的用户

创建数据库weixx

CREATE DATABASE weixx;

#2 创建用户wxx(密码654321) 并允许wxx用户可以从任意机器上登入mysql的weixx数据库
# 任何远程用户都能访问 用户wxx 的数据库。用户root的数据库不能被访问。

GRANT ALL PRIVILEGES ON weixx.* TO wxx@"%" IDENTIFIED BY "654321";
3.3 创建远程访问用户及数据

修改MySql配置文件 (10061 问题,及端口未开放)
netstat -ntlp | grep 3306

vim /etc/mysql/mysql.conf.d/mysqld.cnf

找到bind-address=127.0.0.1 并注释,MySql就可以开启远程访问了(注意检查服务器是否允许访问3306端口)

ubuntu完全卸载mysql

首先查看自己的mysql有哪些依赖

dpkg --list|grep mysql

ubuntu mysql数据文件 ubuntu自带数据库_MySQL_02


先卸载

sudo apt-get remove mysql-common

然后:

sudo apt-get autoremove --purge mysql-server-5.7

再用dpkg --list|grep mysql查看,还剩什么就卸载什么

最后清楚残留数据:

dpkg -l |grep ^rc|awk '{print $2}' |sudo xargs dpkg -P