centos7.2(linux)安装Mysql5.7.17实例-精确到每一步细节.docx_第1页
centos7.2(linux)安装Mysql5.7.17实例-精确到每一步细节.docx_第2页
centos7.2(linux)安装Mysql5.7.17实例-精确到每一步细节.docx_第3页
centos7.2(linux)安装Mysql5.7.17实例-精确到每一步细节.docx_第4页
centos7.2(linux)安装Mysql5.7.17实例-精确到每一步细节.docx_第5页
已阅读5页,还剩5页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

介绍:MySQL的安装方法有多种,如yum安装,rpm包安装,源码编译安装等。其中:用yum命令安装最为方便快捷,但是其版本往往不是最新版,网上教程也是很多.rpm包安装会相对快一些,也可以在官网下载到最新版本进行安装源码安装方式最为复杂,但是是最灵活的,因为安装是可以自定义mysql服务器安装路径,可以自定义数据仓库存放路径,可以自定义端口等等截止17年3月5日(写本教程的时间),centos最新版为7.2,mysql最新版为5.7.17,本教程用的是腾讯服务器,系统和数据库安装均为最新版1、检测是否有旧版# rpm -qa | grep mysql刚重装过的系统,没有旧版。有的话通过下面的命令来卸载掉。卸载前需要停止mysql运行卸载命令2、安装相关文件# yum -y install gcc-c+ ncurses-devel cmake autoconf automake libtool bison make perl gcc libgcrypt卸载boost-*等库:# yum -y remove boost-*这里为了省事就用yum来安装,有的即使不是最新版也不影响使用,很多应用可能用了这一次就不会再用了。并且有的是不可不安装的,但是我也不是非常清楚,所以就全部安装了,大不了用完后卸载。当然不嫌麻烦的话可以去各自官网下载安装,安装好后可以检查所需工具是否按照完成,比如我要坚持“gcc-c+”是否安装完成,可以使用# rpm -qa | grep gcc-c+其实没必要看,用yum命令安装的话一般不会错,如果不放心的话还可以以上的方式查看其他的3、去官网下载mysql源码包官网:/-这里最好下载下面的一个,如果没有记错的话,在下载上面一个并且系统没有Boost包的情况下在后面操作中会自己下载。注意:在点击下载后会让登录帐号,没有就注册一个登录后下载在即将下载的时候,我们将下载地址栏的地址复制后就可以的(比如360浏览器操作如下):复制好下载地址后就放到服务器中下载# wget /Downloads/MySQL-5.7/mysql-boost-5.7.17.tar.gz注意在服务器中要在前面加上wget3、安装操作1.)下载完成后将下载的包复制或移动到数据库的安装位置,比如我服务器用root登录的,所以包下载后在 /root 目录下,而我要将数据库安装在/SQL目录下,命令为:# cp /root/mysql-boost-5.7.17.tar.gz /SQL2.)解压# cd /SQL-转到/SQL目录下# tar -xzf mysql-boost-5.7.17.tar.gz-解压操作此时解压后的文件夹为“mysql-5.7.17“,而不是”mysql-boost-5.7.17“用命令 # ls 可查看3.)编译和安装a. 进入安装包所在文件夹# cd mysql-5.7.17-进入该文件夹由图可知cd mysql-5.7.17内确有boost文件,即boost路径为:/SQL/ mysql-5.7.17/boost-该路径等会要用b. 创建mysql用户, 组及目录(这里升级的用户可能提示已存在,请滤过)# groupadd mysql-创建mysql用户# mkdir -p /SQL/mysql-在SQL文件夹下创建mysql文件夹# mkdir -p /SQL/sqldata-在SQL文件夹下创建sqldata# useradd -g mysql /mysql-将mysql用户(后者)分配到mysql组中(前者)# chown -R mysql:mysql /SQL/mysql/ c. 设置自定义属性(最为关键弄错了会导致后面编译报错)命令为:(一条一条复制,出最后一条外,其余每条后面都有反斜杠,前面的#和不要)# cmake -DCMAKE_INSTALL_PREFIX=/SQL/mysql -安装路劲 -DMYSQL_DATADIR=/SQL/sqldata -数据存放位置 -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DMYSQL_TCP_PORT=3306 -DMYSQL_USER=mysql -DWITH_MYISAM_STORAGE_ENGINE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_ARCHIVE_STORAGE_ENGINE=1 -DWITH_BLACKHOLE_STORAGE_ENGINE=1 -DWITH_MEMORY_STORAGE_ENGINE=1 -DDOWNLOAD_BOOST=1 -DWITH_BOOST=/SQL/mysql-5.7.17/boost-boost所在路径如果出错时,检测参数后重新运行配置,需要删除CMakeCache.txt文件# make clean # rm -f CMakeCache.txt还有很多参数,但是有的很重要。下面是网上的,供参考d、编译# make如果使用小内存云服务器编译,一般会在45%左右编译出错,设置虚拟内存即可.错误如上设置虚拟内存的命令:# dd if=/dev/zero of=/swapfile bs=1k count=2048000 -获取要增加的2G的SWAP文件块# mkswap /swapfile - 创建SWAP文件# swapon /swapfile - 激活SWAP文件# swapon -s - 查看SWAP信息是否正确# echo /var/swapfile swap swap defaults 0 0 /etc/fstab - 添加到fstab文件中让系统引导时自动启动注意, swapfile文件的路径在/var/下 编译完后, 如果不想要交换分区了, 可以删除:# swapoff /swapfile# rm -fr /swapfile设置好后重新运行 # make 命令编译安装完成e、安装# make install安装完成至此,mysql服务器就按照完成了,接下来就是繁琐的配置其实可以直接从官网下载已经编译好的二进制文件解压到/usr/etc即可开始后面的配置,省了不少麻烦.f、设置初始化在5.5和5.6版本中,mysql数据库是使用mysqld_db_install命令进行初始化的;在5.7之后,数据库初始化发生了改变,需要mysqld命令进行初始化# /SQL/mysql/bin/mysqld -initialize -defaults-file=/etc/f -user=mysql -datadir=/SQL/mysql/data -basedir=/SQL/mysql如果以上命令执行失败可尝试将上一条中” initialize”删除说明:-datadir=后面为mysql数据层房位置-basedir=后面为mysql软件的位置添加mysqld系统服务:# cp /SQL/mysql-5.7.17/support-files/mysql.server /etc/init.d/mysqld-加入系统启动# chmod +x /etc/init.d/mysqld# chmod 755 /etc/init.d/mysqld# chkconfig -add mysqld# chkconfig -level 2345 mysqld on-加入开机自动启动# chkconfig -list | grep mysqld添加加载mysql库文件的路径:添加加载mysql库文件的路径:# echo /SQL/mysql/lib /etc/ld.so.conf.d/mysql-x86_64.conf# echo /usr/lib64/mysql /etc/ld.so.conf.d/mysql-x86_64.conf# cp /etc/ld.so.conf.d/mysql-x86_64.conf /etc/ld.so.conf.d/mysql.conf# ldconfig# ln -s /SQL/mysql/lib/mysql /usr/lib64/mysql# ln -s /SQL/mysql/include/mysql /usr/include/mysql以上两个软连接作用为把mysql库文件链接到系统默认位置,以后类似PHP等软件就可以不指定mysql的库文件地址# ln -s /SQL/mysql/bin/mysql /usr/bin/mysql# ln -s /SQL/mysql/bin/mysqldump /usr/bin/mysqldump# ln -s /SQL/mysql/bin/myisamchk /usr/bin/myisamchk# ln -s /SQL/mysql/bin/mysqld_safe /usr/bin/mysqld_safe# ln -s /SQL/mysql/bin/mysqladmin /usr/bin/mysqladmin# mkdir /var/lib/mysql # ln -s /tmp/mysql.sock /var/lib/mysql/mysql.sock以上两步操作为创建mysql启动文件 mysql.sock 软链接。(mysql.sock作用是例如你无须定义连接host的具体IP地址,只要为空或localhost就可以,如果文件被删除掉就使用localhost用户连接不到mysql服务器。)f文件处理# mv /etc/f /etc/f.bak-备份原来的或者删除原来的# rm -f /etc/f# cp /SQL/mysql/support-files/f /SQL/mysql/f-复制安装路径里的文件到上一级,并且重命名为f# ln -s /SQL/mysql/f /etc-将f链接到/etc/etc/init.d/mysqld文件处理等号后面补全/并且修改相应部分basedir=/SQL/mysqldatadir=/SQL/mysql/data 这里为数据库存放地址,根据实际修改e、启动启动脚本有两个,分别是/usr/local/mysql/bin/mysqld_safe 和/usr/local/mysql/support-files/mysql.server(即/etc/init.d/mysqld)。当启动mysqld时,mysqld_safe同时启动,mysqld_safe监控mysqld服务,记录错误日志,并在mysqld因故障停止时将其重启。# /etc/init.d/mysqld start-启动# /etc/init.d/mysqld stop-停止# /etc/init.d/mysqld status-查看状态f、重置密码(新版mysql会生成一个初始密码,可以通过命令获得,也可以通过此方法重置密码)在/etc/f中增加一行skip-grant-tables 如:重启mysql软件(可通过上面命令关闭后再开启)用户登录# mysql -uroot -p (直接点击回车,密码为空)选择数据库use mysql; -(后面有分号) update user set authentication_string=PASSWORD(newpass) where User=root #5.7.5 之前命令如下 update user set password=PASSWORD(newpass) where User=root; exit -退出退出后,删除在/etc/f内容里的(skip-grant-tables),保存退出,重启MSYQL服务进入MSYQL,使用新密码登录当登录进入 mysql数据库时会报如下错误,原因在于我们虽然重置了密码,但是系统还是认为刚刚的密码是初始密码(初始密码不安全),解决如下:# SET PASSWORD = PASSWORD( newpass );现在就可以了 新密码为”newpass”g、其他操作查看已经创建的用户及允许连接的主机MySQL (none)use mysql;MySQL mysql SELECT User, Password, Host FROM user; #查看现有用户,密码及允许连接的主机MySQL mysql SELECT User, Host FROM user; #新版不支持查看密码创建用户wordpress数据库所有权限,先登录数据库,然后命令如下MySQL (none) grant all privileges on wordpress.* to db_rootlocalhost identified by 123456; #授权语句,特别注意有分号MySQL (none) flush privileges; #权限立即生效MySQL (none) exit; #退出数据库控制台,特别注意有分号-添加一个新的 root 用户, 密码为空, 只允许 00 连接mysql GRANT ALL PRIVILEGES ON *.* TO root00 IDENTIFIED BY WITH GRANT OPTION;开放远程连接(需要在安全组开放33

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论