zoukankan      html  css  js  c++  java
  • MySQL5.6 linux源码安装

    安装mysql  

    创建mysql数据目录

    mkdir -p /usr/local/mysql       --安装目录
    
    mkdir -p /mysql/data   ---数据目录

    mkdir -p /mysql/log ---日志目录

    创建mysql用户和组

    groupadd mysql
    
    useradd -r -g mysql mysql

    安装插件

    yum  -y install gcc gcc-c++ autoconf bison cmake automake zlib* fiex* libxml* ncurses-devel libmcrypt* libtool-ltdl-devel*

    编译安装

    wget http://dev.mysql.com/get/Downloads/MySQL-5.6/mysql-5.6.15.tar.gz

    cmake 
    -DCMAKE_INSTALL_PREFIX=/usr/local/mysql 
    -DMYSQL_DATADIR=/mysql/data 
    -DSYSCONFDIR=/etc 
    -DWITH_MYISAM_STORAGE_ENGINE=1 
    -DWITH_INNOBASE_STORAGE_ENGINE=1 
    -DWITH_MEMORY_STORAGE_ENGINE=1 
    -DWITH_FEDERATED_STORAGE_ENGINE=1 
    -DWITH_READLINE=1 
    -DMYSQL_UNIX_ADDR=/tmp/mysql.sock 
    -DMYSQL_TCP_PORT=3306 
    -DENABLED_LOCAL_INFILE=1 
    -DWITH_PARTITION_STORAGE_ENGINE=1 
    -DEXTRA_CHARSETS=all 
    -DDEFAULT_CHARSET=utf8 
    -DDEFAULT_COLLATION=utf8_general_ci
    make
    
    make install

    具体选项可参考mysql官方:http://dev.mysql.com/doc/refman/5.5/en/source-configuration-options.html

    -DCMAKE_INSTALL_PREFIX=/usr/local/mysql        //安装目录

    -DINSTALL_DATADIR=/usr/local/mysql/data         //数据库存放目录

    -DDEFAULT_CHARSET=utf8                        //使用utf8字符

    -DDEFAULT_COLLATION=utf8_general_ci            //校验字符

    -DEXTRA_CHARSETS=all                            //安装所有扩展字符集

    -DENABLED_LOCAL_INFILE=1                        //允许从本地导入数据

    -DINSTALL_SBINDIR=                     mysqlid目录

    -DSYSCONFDIR=                              my.cnf配置文件目录

    -DINSTALL_PLUGINDIR=                 插件目录

    -DINSTALL_MANDIR=                      手册文件目录

    -DINSTALL_SHAREDIR=                  共享数据目录

    -DINSTALL_LIBDIR=                        library库目录

    -DINSTALL_INCLUDEDIR=               header安装目录

    -DINSTALL_INFODIR=                            信息文档目录

    存储引擎相关参数(- DWITH代表启用,-DWITHOUT代表不启用,mysql默认支持的数据库引擎有MyISAM, MERGE, MEMORY, CSV,无需在编译时再声明):

    -DWITH_MYISAM_STORAGE_ENGINE=1

    -DWITH_INNOBASE_STORAGE_ENGINE=1

    -DWITH_MEMORY_STORAGE_ENGINE=1

    -DWITH_FEDERATED_STORAGE_ENGINE=1

    -DWITH_PARTITION_STORAGE_ENGINE=1

    -DWITH_ARCHIVE_STORAGE_ENGINE=1

    授予mysql用户权限

    chown -R mysql:mysql /usr/local/mysql

    创建系统自带的数据库和表

    cd /usr/local/mysql
    scripts/mysql_install_db --basedir=/usr/local/mysql --datadir=/mysql/data --user=mysql --defaults-file=/etc/my.cnf --innodb_undo_tablespaces=3 --explicit_defaults_for_timestamp 
    
    有时候执行可能会提示参数“--explicit_defaults_for_timestamp”的错误
    scripts/mysql_install_db --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data  --innodb_undo_tablespaces=3  --user=mysql --explicit_defaults_for_timestamp
    
    该参数是开启独立的undolog,从一个已经开启了undolog独立文件的服务器上面将目录下的系统库和undolog文件拷贝到新的服务器上面也可以开启新的服务器的独立undolog,但是不建议这样操作因为暂时还没有发现这样错会存在什么问题。

      chown -R mysql:mysql /usr/local/mysql  /mysql

      mv /usr/local/mysql/my.cnf /etc/my.cnf

    注意:从一台服务器物理拷贝整个数据库到另一台服务器记得修改auto.conf文件中的UUID

    配置mysql启动服务

    进入源码包文件
    
    cp support-files/mysql.server /etc/init.d/mysql
    
    chmod +x /etc/init.d/mysql   --授予文件可执行权限
    
    chkconfig mysql on  --配置mysql开机自动启动
    
    service mysql start  --启动MySQL

    配置环境变量

    为了能直接调用mysql命令,需要配置环境变量
    
    vim /etc/profile
    
    在/etc/profile文件末尾添加
    
    export PATH=/usr/local/mysql/bin:$PATH
    
    使环境变量立即生效
    
    source /etc/profile

    设置mysql root用户密码

    默认mysql root用户安装完密码为空
    
    mysql -uroot  ---登入
    
    SET PASSWORD = PASSWORD('root');  --设置root密码
    
    默认root只运行本地访问
    
    use mysql
    
    select user,host from user where user='root';
    
    授予root远程连接权限,生产环境慎用
    
    GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'root' WITH GRANT OPTION;

    创建备份用户

    grant reload,lock tables,replication client,create tablespace,super on *.* to 'backup'@'%' identified by 'backup';

    防火墙配置

    默认3306端口是未启用,启用3306端口
    
    vim /etc/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

    centos7操作系统防火墙还需要修改的地方有:

    Firewalld中添加端口方法如下:

    firewall-cmd --zone=public --add-port=3306/tcp --permanent

    firewall-cmd --reload

    总结  

    如果更改.sock的默认路径,需要在本机登入那么[client]中也要配置socket,实际的业务系统需要将日志文件和数据文件分开磁盘存放,可以在my.cnf文件中配置。

    备注:

        作者:pursuer.chen

        博客:http://www.cnblogs.com/chenmh

    本站点所有随笔都是原创,欢迎大家转载;但转载时必须注明文章来源,且在文章开头明显处给明链接。

    《欢迎交流讨论》

  • 相关阅读:
    element-ui做表单验证 v-for遍历表单 自动生成校验规则 pc移动双适配
    element-ui练习使用总结
    js监听页面标签切换
    对象数组,按照没想中特定的属性(按中文拼音)排序
    调用七牛云存储文件,返回url
    javascript中的class类 以及class的继承
    javascript原型继承
    javascript面向对象 用new创建一个基于原型的javascript对象
    java中的变量和数据类型
    css的伪元素
  • 原文地址:https://www.cnblogs.com/chenmh/p/5250801.html
Copyright © 2011-2022 走看看