Ubuntu 16.04下如何安装MariaDB

1.  安装指令

sudo apt install software-properties-common

sudo apt-key adv --recv-keys --keyserver hkp://keyserver.ubuntu.com:80 0xF1656F24C74CD1D8
执行结果:
 Executing: /tmp/tmp.p9r0OfEIH2/gpg.1.sh --recv-keys
--keyserver
hkp://keyserver.ubuntu.com:80
0xF1656F24C74CD1D8
gpg: requesting key C74CD1D8 from hkp server keyserver.ubuntu.com
gpg: key C74CD1D8: public key "MariaDB Signing Key <[email protected]>" imported
gpg: Total number processed: 1
gpg:&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; imported: 1&nbsp; (RSA: 1)

sudo add-apt-repository 'deb [arch=amd64,i386,ppc64el] http://mirrors.tuna.tsinghua.edu.cn/mariadb/repo/10.2/ubuntu xenial main'

这里选中清华的数据服务

sudo apt update

执行结果如下:

>> sudo apt install mariadb-server

Reading package lists... Done
Building dependency tree     
Reading state information... Done
The following packages were automatically installed and are no longer required:
  linux-headers-4.4.0-28 linux-headers-4.4.0-28-generic linux-image-4.4.0-28-generic linux-image-extra-4.4.0-28-generic
Use 'sudo apt autoremove' to remove them.
The following additional packages will be installed:
  galera-3 gawk iproute libjemalloc1 libmariadbclient18 libmysqlclient18 mariadb-client-10.2 mariadb-client-core-10.2 mariadb-common
  mariadb-server-10.2 mariadb-server-core-10.2 socat
Suggested packages:
  gawk-doc mailx mariadb-test tinyca
The following packages will be REMOVED:
  mariadb-client-10.0 mariadb-client-core-10.0 mariadb-server-10.0 mariadb-server-core-10.0
The following NEW packages will be installed:
  galera-3 gawk iproute libjemalloc1 libmariadbclient18 libmysqlclient18 mariadb-client-10.2 mariadb-client-core-10.2 mariadb-server-10.2
  mariadb-server-core-10.2 socat
The following packages will be upgraded:
  mariadb-common mariadb-server
2 upgraded, 11 newly installed, 4 to remove and 1 not upgraded.
Need to get 21.8 MB of archives.
After this operation, 48.4 MB of additional disk space will be used.
Do you want to continue? [Y/n] y
Get:1 http://ftp.osuosl.org/pub/mariadb/repo/10.2/ubuntu xenial/main amd64 galera-3 amd64 25.3.15-xenial [7,741 kB]
Get:2 http://mirrors.aliyun.com/ubuntu xenial/main amd64 gawk amd64 1:4.1.3+dfsg-0.1 [398 kB]
Get:3 http://mirrors.aliyun.com/ubuntu xenial/main amd64 iproute all 1:4.3.0-1ubuntu3 [2,428 B]                                                     
Get:4 http://mirrors.aliyun.com/ubuntu xenial/universe amd64 libjemalloc1 amd64 3.6.0-9ubuntu1 [78.9 kB]                                           
Get:5 http://mirrors.aliyun.com/ubuntu xenial/universe amd64 socat amd64 1.7.3.1-1 [321 kB]                                                         
Get:6 http://ftp.osuosl.org/pub/mariadb/repo/10.2/ubuntu xenial/main amd64 mariadb-server all 10.2.1+maria-1~xenial [2,960 B]                       
Get:7 http://ftp.osuosl.org/pub/mariadb/repo/10.2/ubuntu xenial/main amd64 libmysqlclient18 amd64 10.2.1+maria-1~xenial [2,932 B]                   
Get:8 http://ftp.osuosl.org/pub/mariadb/repo/10.2/ubuntu xenial/main amd64 mariadb-common all 10.2.1+maria-1~xenial [3,234 B]                       
Get:9 http://ftp.osuosl.org/pub/mariadb/repo/10.2/ubuntu xenial/main amd64 libmariadbclient18 amd64 10.2.1+maria-1~xenial [583 kB]                 
Get:10 http://ftp.osuosl.org/pub/mariadb/repo/10.2/ubuntu xenial/main amd64 mariadb-client-core-10.2 amd64 10.2.1+maria-1~xenial [689 kB]           
Get:11 http://ftp.osuosl.org/pub/mariadb/repo/10.2/ubuntu xenial/main amd64 mariadb-client-10.2 amd64 10.2.1+maria-1~xenial [1,095 kB]             
Get:12 http://ftp.osuosl.org/pub/mariadb/repo/10.2/ubuntu xenial/main amd64 mariadb-server-core-10.2 amd64 10.2.1+maria-1~xenial [4,456 kB] 

2. 查看sourcelist.

 >>  sudo vi /etc/apt/sources.list

# MariaDB 10.2 repository list - created 2016-08-14 12:39 UTC
# http://downloads.mariadb.org/mariadb/repositories/
deb [arch=amd64,i386] http://mirrors.tuna.tsinghua.edu.cn/mariadb/repo/10.2/ubuntu xenial main
deb-src http://mirrors.tuna.tsinghua.edu.cn/mariadb/repo/10.2/ubuntu xenial main

3. 无法连接Mariadb的问题

安装完成Mariadb之后,基于mysql workbench无法连接mariadb, 提示"Plugin 'unix_socket' is not loaded"的错误细心:

Ubuntu 16.04下如何安装MariaDB

什么是unix_socket plugin?

是一种安全机制,允许使用操作系统的安全机制连接数据库,通过unix_socket组件,通常使用用在Ubuntu 15.04+以上的系统中。

解决的方法:

1.  尝试登陆mysql的命令, mysql -u root -p, 如果看到如下错误,则需要进入步骤2,否则直接进入步骤6.

这个原因是由于当前使用的unix_socket来进行连接,但是缺省的用户也无法进行访问。

     2. 停止服务,使用设置native方式来访问,重置缺省密码

   >> sudo systemctl stop mariadb  # 停止服务

   >> sudo mysqld_safe --skip-grant-tables &  # 进入安全模式,并设置为后台进程

>> mysql -u root   # 登陆mysql

>>  select Host,User,plugin from mysql.user where User='root';  # 查询用户

>> update mysql.user set plugin='mysql_native_password';  #重置加密模式

   >> update mysql.user set password=PASSWORD("newpassword") where User='root';  #重置密码

   >>  flush privileges;  #刷新权限信息

>>  exit

Ubuntu 16.04下如何安装MariaDB

杀掉进程,重新启动服务

 >> sudo kill -9 $(pgrep mysql)  # 杀掉进程

 >> sudo service mariadb start # 重新启动服务

3. 登陆mysql, 安装unix_soket

>> mysql -u root -p

  >> install plugin unix_socket soname 'auth_socket';

Ubuntu 16.04下如何安装MariaDB

然后就可以正常访问了。

MariaDB 的详细介绍请点这里
MariaDB 的下载地址请点这里

猜你喜欢

转载自www.linuxidc.com/Linux/2017-04/142915.htm
今日推荐