Linux下安装mysql数据库
一、前言
在Linux下安MySQL数据库主要有三种方式,分别是:
1 RPM包安装;
2 使用已经编译好的安装包;
3 源码编译安装。
本文以安装mysql5.7.27版本为例,介绍这三种安装方式。
二、系统环境
虚拟机VMware Workstation安装Centos6.5系统,操作前/etc/selinux/config中的SELINUX设置及disabled。
三、数据库
3.1 RPM包安装
3.1.1 yum远程包
1)下载rpm
wget https://repo.mysql.com//mysql80-community-release-el6-3.noarch.rpm --no-check-certificate
2) 安装rpm
rpm -ivh mysql80-community-release-el6-3.noarch.rpm
安装完成之后执行:yum repolist all | grep mysql 查看哪些版本可以安装
[root@base ~]# yum repolist all | grep mysql mysql-cluster-7.5-community MySQL Cluster 7.5 Community disabled mysql-cluster-7.5-community-source MySQL Cluster 7.5 Community - disabled mysql-cluster-7.6-community MySQL Cluster 7.6 Community disabled mysql-cluster-7.6-community-source MySQL Cluster 7.6 Community - disabled mysql-cluster-8.0-community MySQL Cluster 8.0 Community disabled mysql-cluster-8.0-community-source MySQL Cluster 8.0 Community - disabled mysql-connectors-community MySQL Connectors Community enabled: 102 mysql-connectors-community-source MySQL Connectors Community - S disabled mysql-tools-community MySQL Tools Community enabled: 81 mysql-tools-community-source MySQL Tools Community - Source disabled mysql-tools-preview MySQL Tools Preview disabled mysql-tools-preview-source MySQL Tools Preview - Source disabled mysql55-community MySQL 5.5 Community Server disabled mysql55-community-source MySQL 5.5 Community Server - S disabled mysql56-community MySQL 5.6 Community Server disabled mysql56-community-source MySQL 5.6 Community Server - S disabled mysql57-community MySQL 5.7 Community Server disabled mysql57-community-source MySQL 5.7 Community Server - S disabled mysql80-community MySQL 8.0 Community Server enabled: 113 mysql80-community-source MySQL 8.0 Community Server - S disabled
需要使用特定版本的,执行[如果不设置,会安装最新的版本,这里设置mysql57版本]:
shell> yum-config-manager --disable mysql80-community
shell> yum-config-manager --enable mysql57-community
3) 安装mysql
yum install -y mysql-community-server
3.1.2 yum本地包
有两种方式,一种是使用下载rpm-bundle并且上传到服务器, 一种是下载rpm包,这里介绍下载rpm包的方式:
wget https://cdn.mysql.com//Downloads/MySQL-5.7/mysql-community-server-5.7.27-1.el6.x86_64.rpm
yum localinstall mysql-community-server-5.7.27-1.el6.x86_64.rpm
安装完成之后配置/etc/my.cnf文件,再启动数据库即可使用。
root用户的初始密码可通过如下命令查看:
grep 'temporary password' /var/log/mysqld.log#my.cnf中配置的错误日志文件
3.2 使用已经编译好的安装包
1)下载安装包
wget --no-check-certificate http://mirrors.sohu.com/mysql/MySQL-5.7/mysql-5.7.27-linux-glibc2.12-x86_64.tar
2)解压后,mv到指定目录
3)编辑配置文件
vim /etc/my.cnf
4)安装服务端:
#数据文件目录是/u01/app/mysql/data
#cd /u01/app/mysql
#mkdir -p log
#touch log/mysql_error.log
#chown -R mysql:mysql log
bin/mysqld --user=mysql --basedir=/u01/app/mysql --datadir=/u01/app/mysql/data --initialize 安装
cp support-files/mysql.server /etc/init.d/mysqld
5)添加环境变量
vim ~/.bash_profile
export MYSQL_HOME=/u01/app/mysql
export PATH=$MYSQL_HOME/bin:$PATH
source ~/.bash_profile
6)启动数据库
查看密码:
grep 'temporary password' log/mysql_error.log
service mysqld start
3.3 源码编译安装
MySQL5.7 源码编译安装比5.6多了一个boost,可以直接下载带有boost的源码,具体安装步骤见以下代码:
#/usr/bin # #1.检查是否安装了mysql,如果已经安装了,则要把原先的版本卸载掉 #rpm -qa|grep mysql for i in `rpm -qa | grep "mysql"`; do rpm -e --allmatches $i --nodeps; done #2.安装必要的软件包 yum install -y make gcc-c++ cmake bison-devel ncurses-devel yum install -y gcc gcc-c++ kernel-devel yum install -y readline-devel pcre-devel openssl-devel openssl zlib zlib-devel pcre-devel #3.下载mysql,如果已经下载文件,请修改这部分 cd /home #只是习惯把文件下载到/home目录下 wget --no-check-certificate http://mirrors.sohu.com/mysql/MySQL-5.7/mysql-boost-5.7.27.tar.gz #wget --no-check-certificate https://sourceforge.net/projects/boost/files/boost/1.59.0/boost_1_59_0.tar.gz/ #tar xf boost_1_59_0.tar.gz -C /usr/local/boost tar -zxvf mysql-boost-5.7.27.tar.gz cd mysql-5.7.27 #4.使用cmake编译 mysql_home=/u01/app/mysql #自定义地址 if [ ! -d "$mysql_home" ]; then mkdir -p "$mysql_home" fi cmake -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_BOOST=boost make && make install #2.新建mysql的用户 user=mysql group=dba #create group if not exists egrep "^$group" /etc/group >& /dev/null if [ $? -ne 0 ] then groupadd $group fi #create user if not exists egrep "^$user" /etc/passwd >& /dev/null if [ $? -ne 0 ] then useradd -g $group $user fi if [ ! -d "$mysql_home/data" ]; then mkdir -p "$mysql_home/data" fi if [ ! -d "$mysql_home/run" ]; then mkdir -p "$mysql_home/run" fi if [ ! -d "$mysql_home/log" ]; then mkdir -p "$mysql_home/log" fi #这里有可能报错,会导致数据库服务开不起来,后来把--datadir=$mysql_home/data后重跑一遍就可以开启服务了 cd $mysql_home bin/mysqld --user=mysql --basedir=$mysql_home --datadir=$mysql_home/data --initialize chown -R mysql:dba $mysql_home #注册服务 cd $mysql_home/support-files cp mysql.server /etc/init.d/mysqld #拷贝配置文件 #cp /mnt/hgfs/virtual_share_file/my_adjust.cnf $mysql_home/my.cnf #开机启动 chkconfig mysqld on
四、总结
以上三种安装方式,都只做了简要介绍,并未有具体的安装步骤,仅做参考。