Linux安装Mysql5.6
来源:SegmentFault
时间:2023-02-19 13:14:18 499浏览 收藏
亲爱的编程学习爱好者,如果你点开了这篇文章,说明你对《Linux安装Mysql5.6》很感兴趣。本篇文章就来给大家详细解析一下,主要介绍一下MySQL、Linux、Socket、MYSQL5.6、mysqld,希望所有认真读完的童鞋们,都有实质性的提高。
由于安装的
mysql8.0和其他服务器的数据库(版本
5.1.30)由于版本差异过大,无法通信,因此需要安装一个中间版本
5.6,但是它的安装过程和mysql8.0安装略有不同。
解压文件
// 解压文件生成两个xz格式的压缩文件 $ tar -xzvf mysql-5.6.42-linux-glibc2.12-x86_64.tar.gz // 为了方便查找,改个名字 mv mysql-5.6.42-linux-glibc2.12-x86_64 mysql5 // 为了使用mysql快速初始化,链接到指定目录 ln -s /home/work/lnmp/mysql5/ /usr/local/mysql
环境配置
我们需要专门的
mysql进程启动用户和权限管理:
// 创建mysql系统用户和用户组 useradd -r mysql // 给予安装目录mysql权限 chown mysql:mysql -R mysql5
配置自己的
mysql配置文件,因为我有多个
Mysql库,我手动指定很多参数:
[client] socket=/home/work/lnmp/mysql5/tmp/mysql.sock default-character-set=utf8 [mysql] basedir=/home/work/lnmp/mysql5/ datadir=/home/work/lnmp/mysql5/data/ socket=/home/work/lnmp/mysql5/tmp/mysql.sock port=3306 user=mysql # 指定日志时间为系统时间 log_timestamps=SYSTEM log-error=/home/work/lnmp/mysql5/log/mysql.err [mysqld] basedir=/home/work/lnmp/mysql5/ datadir=/home/work/lnmp/mysql5/data/ socket=/home/work/lnmp/mysql5/tmp/mysql.sock port=3306 user=mysql log_timestamps=SYSTEM collation-server = utf8_unicode_ci character-set-server = utf8 [mysqld_safe] log-error=/home/work/lnmp/mysql5/log/mysqld_safe.err pid-file=/home/work/lnmp/mysql5/tmp/mysqld.pid socket=/home/work/lnmp/mysql5/tmp/mysql.sock [mysql.server] basedir=/home/work/lnmp/mysql5 socket=/home/work/lnmp/mysql5/tmp/mysql.sock [mysqladmin] socket=/home/work/lnmp/mysql5/tmp/mysql.sock
这个里面我指定了错误日志的路径,在接下来的操作中,如果出现错误,除了查看终端显示的错误,还要记得去错误日志里查看详细的信息。
因为我指定了一些文件,所以需要提前创建:
mkdir log touch log/mysql.err touch log/mysqld_safe.err mkdir tmp mkdir data cd .. & chown mysql:mysql -R mysql5
数据库初始化
如果我们不初始化,直接使用
bin/mysqld_safe启动会报错,因为我们需要初始化
mysql环境,具体的操作可以参考官方文档:
$ scripts/mysql_install_db --user=mysql ... To start mysqld at boot time you have to copy support-files/mysql.server to the right place for your system PLEASE REMEMBER TO SET A PASSWORD FOR THE MySQL root USER ! To do so, start the server, then issue the following commands: ./bin/mysqladmin -u root password 'new-password' ./bin/mysqladmin -u root -h szwg-cdn-ai-predict00.szwg01.baidu.com password 'new-password' Alternatively you can run: ./bin/mysql_secure_installation which will also give you the option of removing the test databases and anonymous user created by default. This is strongly recommended for production servers. See the manual for more instructions. You can start the MySQL daemon with: cd . ; ./bin/mysqld_safe & You can test the MySQL daemon with mysql-test-run.pl cd mysql-test ; perl mysql-test-run.pl Please report any problems at http://bugs.mysql.com/ The latest information about MySQL is available on the web at http://www.mysql.com Support MySQL by buying support/licenses at http://shop.mysql.com WARNING: Found existing config file ./my.cnf on the system. Because this file might be in use, it was not replaced, but was used in bootstrap (unless you used --defaults-file) and when you later start the server. The new default config file was created as ./my-new.cnf, please compare it with your file and take the changes you need.
提示中提示我们已经创建了
root的用户,需要修改临时密码,同时初始化成功。也告诉我们怎么启动一个数据库实例。
启动数据库
我们使用
mysqld_safe命令来启动:
$ bin/mysqld_safe 181217 14:55:08 mysqld_safe Logging to '/home/work/lnmp/mysql5/log/mysqld_safe.err'. 181217 14:55:08 mysqld_safe Starting mysqld daemon with databases from /home/work/lnmp/mysql5/data
链接全局命令
此时,我们调用
mysql只能用路径
/home/work/lnmp/mysql8/bin/mysql或相对路径,需要链接为全局命令:
$ ln -s /home/work/lnmp/mysql8/bin/mysql /usr/bin/ $ ln -s /home/work/lnmp/mysql8/bin/mysql_safe /usr/bin/
打开数据库
数据库进程已经启动,我们可以在新终端正常使用
mysql数据库,但是直接使用
mysql命令报错:
$ mysql -uroot ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)
我查看了官方安装多个数据库的文档,尝试了很多方法,依然没有办法指定
mysql命令的默认
socket路径
(/tmp/mysql.sock)。但是根据mysql.sock的作用的说明,我们指定
mysql.sock路径即可:
bin/mysql -S /home/work/lnmp/mysql8/tmp/mysql.sock -h localhost -uroot -p Enter password:
或者:
ln -s /home/work/lnmp/mysql8/tmp/mysql.sock /tmp/
然后我们再调用
mysql命令就不会报错了。
修改初始密码
初始化的时候,命令行文本已经提示我们需要怎样更新
root密码,并根据他的指示操作即可,要详细阅读输出的文本:
$ bin/mysql_secure_installation NOTE: RUNNING ALL PARTS OF THIS SCRIPT IS RECOMMENDED FOR ALL MySQL SERVERS IN PRODUCTION USE! PLEASE READ EACH STEP CAREFULLY! In order to log into MySQL to secure it, we'll need the current password for the root user. If you've just installed MySQL, and you haven't set the root password yet, the password will be blank, so you should just press enter here. Enter current password for root (enter for none): OK, successfully used password, moving on... Setting the root password ensures that nobody can log into the MySQL root user without the proper authorisation. Set root password? [Y/n] y New password: Re-enter new password: Password updated successfully! Reloading privilege tables.. ... Success!
连接数据库,新密码已经更新。
参考文章
- mysql8.0安装:https://segmentfault.com/a/11...
- mysql8.0初始化:https://dev.mysql.com/doc/ref...
文中关于mysql的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《Linux安装Mysql5.6》文章吧,也可关注golang学习网公众号了解相关技术文章。
声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
-
499 收藏
-
244 收藏
-
235 收藏
-
157 收藏
-
101 收藏
最新阅读
更多>
-
475 收藏
-
266 收藏
-
273 收藏
-
283 收藏
-
210 收藏
-
371 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习