• 检查系统是否自带/已安装了Mysql

  • yum list installed | grep mysql

     

  • 有发现自带/已安装Mysql,卸载删除

  • yum -y remove mysql*

     

  • 在存放文件目录执行

  • wget http://repo.mysql.com/mysql-community-release-el6-5.noarch.rpm

     

  • 接着执行这句,

  • rpm -ivh mysql-community-release-el6-5.noarch.rpm

    解释一下,这个rpm还不是mysql的安装文件,只是两个yum源文件,执行后,在/etc/yum.repos.d/  这个目录下多出mysql-community-source.repo和mysql-community.repo

     

  • 查看是否已有Mysql可安装文件

  • yum repolist all | grep mysql

     

  • 安装mysql       服务器命令(一路yes):

  • yum install mysql-community-server

     

  • 安装成功之后执行

  • service mysqld start

     

  • 由于mysql刚刚安装完的时候,mysql的root用户的密码默认是空的,所以我们需要及时用mysql的root用户登录(第一次回车键,不用输入密码),并修改密码

  • mysql -u root

    use mysql;

    update user set password=PASSWORD("这里输入root用户密码")  where User='root';

    flush privileges;

    exit(退出mysql)

     

  • 查看mysql是否自启动,并且设置开启自启动命令

  • chkconfig --list | grep mysqld
      chkconfig mysqld on

     

  • mysql安全设置(系统会一路问你几个问题,看不懂复制之后翻译,基本上一路yes):

  • mysql_secure_installation

     

  • 将Mysql的端口添加防火墙例外

  • CentOS 6

    vim/ets/sysconfig/iptables

    在 -A INPUT -m state--state NEW -m tcp -p  tcp --dport 22 -j ACCEPT 一行的后台添加类似的一行命令即可

    -A INPUT -m state--state NEW -m tcp -p tcp  --dport 3306 -j ACCEPT

    重启防火墙服务   service iptables  restart/start/stop

    CentOS  7

    frrewall-cmd --zone=public --add-port=8180/tcp  --permanent        #添加8180端口

    firewall-cmd --reload                                                                     #重新加载策略配置,以使新配置生效

     

  • 授权指定用户/服务器登陆到Mysql服务器上

  • 1:xxxx(用户名)使用xxxx(密码)从任何主机连接到mysql服务器的话。

    GRANT ALL PRIVILEGES ON *.* TO 'xxxx(用户名)'@'%' IDENTIFIED BY  'xxxx(密码)' WITH GRANT OPTION;

    FLUSH   PRIVILEGES;

     

    2:允许xxxx(用户名)从ip为xxx.xxx.xxx.xxx(ip)的主机连接到mysql服务器,并使用xxxx(密码)作为密码

    GRANT ALL PRIVILEGES ON *.* TO  'xxxx(用户名)'@'xxx.xxx.xxx.xxx(ip)' IDENTIFIED BY 'xxxx(密码)' WITH GRANT OPTION;

    FLUSH   PRIVILEGES;

     

    3:允许xxxx(用户名)从ip为xxx.xxx.xxx.xxx的主机连接到mysql服务器的xxx(数据库),并使用xxxx(密码)作为密码

    GRANT ALL PRIVILEGES ON xxx(数据库).* TO  'xxxx(用户名)'@'xxx.xxx.xxx.xxx(ip)' IDENTIFIED BY 'xxxx(密码)' WITH GRANT OPTION;

    FLUSH   PRIVILEGES;

     

    重启Mysql服务     service mysqld  restart