1.执行代码:cd /usr/local/rsc下载MySQL,我是从搜狐镜像上下载的:http://mirrors.sohu.com/mysql/MySQL-5.5/,我下载的是64位(注意)的,下载:wget http://mirrors.sohu.com/mysql/MySQL-5.5/mysql-5.5.55-linux2.6-x86_64.tar.gz。解压tar zxf mysql-5.5.55-linux2.6-x86_64.tar.gz,有两个说明文件INSTALL-BINARY(二进制安装),打开这个里面是如下代码:

You can find information about installing MySQL at

http://dev.mysql.com/doc/refman/5.5/en/installing.html

The MySQL Reference Manual is also available in various formats on
http://dev.mysql.com/doc; if you're interested in the DocBook XML
sources go to http://dev.mysql.com/doc/index-other.html.

它的意思是按照说明在这个网址:http://dev.mysql.com/doc/refman/5.5/en/installing.html ,然后我们进这个网址,发现一个2.2 Installing MySQL on Unix/Linux Using Generic Binaries的链接,点击进去里面就是安装的说明。看不懂英文,用谷歌翻译啊,其实按照安装里面的步骤也就按上了。本教程也是安装官方的说明安装的。

2.注意中间有这么一句话,是提示你libaio如果没有请安装。安装它的提示执行代码:yum install libaio

shell> yum search libaio # search for info

shell> yum install libaio # install library

再往下就是安装的说明了

注意:第一行为提示1代码,第二行是提示2代码,以此类推,下午将以提示n代码来表述。

1.shell> groupadd mysql

2.shell> useradd -r -g mysql -s /bin/false mysql

3.shell> cd /usr/local

4.shell> tar zxvf /path/to/mysql-VERSION-OS.tar.gz(注意这里是官方demo的压缩包)

5.shell> ln -s full-path-to-mysql-VERSION-OS mysql(给目录做了一个软连接)

6.shell> cd mysql

7.shell> chown -R mysql .

8.shell> chgrp -R mysql .

9.shell> scripts/mysql_install_db --user=mysql(安装mysql会有几个默认的库,这个代码就是初始化那些默认库的)

10.shell> chown -R root .

11.shell> chown -R mysql data

12.# Next command is optional(可选)

13.shell> cp support-files/my-medium.cnf /etc/my.cnf

14.shell> bin/mysqld_safe --user=mysql &(启动MySQL的命令)

15.# Next command is optional(可选)

16.shell> cp support-files/mysql.server /etc/init.d/mysql.server

注意:接下来咱们按照官方给的一步一步做。

4.执行提示1代码 groupadd mysql

5.执行提示2代码:useradd -r -g mysql -s /bin/false mysql

注意看提示3,4,5,6行代码的意思是告诉咱们,要把文件解压到/usr/local,但是咱们把文件解压到了/usr/local/src下面,咱们现在所在的目录还是第一步cd的/usr/local/rsc目录下面,咱们要移动到/usr/local目录下面,提示5代码是只是给目录做了软连接mysql,我这里就不做了,直接把文件名字改成mysql,然后提示6代码是进入这个软连接的目录,也就是咱们改的文件夹名字mysql。

6.执行代码:mv mysql-5.5.55-linux2.6-x86_64 /usr/local/mysql

7.然后进入目录/usr/local,代码:cd /usr/local/mysql

8.执行提示7代码chown -R mysql .

9.执行提示8代码chgrp -R mysql .

10.初始化数据库库执行提示9代码scripts/mysql_install_db --user=mysql

11.启动mysql执行提示14代码./bin/mysqld_safe &然后它提示你有个错误写到了日志/var/log/mysqld.log,查看日志more /var/log/mysqld.log翻到最后有ERROR,错误代码如下

170702 22:32:12 [ERROR] /usr/local/mysql/bin/mysqld: Can't create/write to file '/var/run/mysqld/mysqld.pid' (Errcode: 2)
170702 22:32:12 [ERROR] Can't start server: can't create PID file: No such file or directory(不能创建PID文件,没有这个mysqld目录,我们需要自己创建)

12.创建mysqld目录mkdir /var/run/mysqld

13.再启动./bin/mysqld_safe &你发现还是提示你有错误写到日志了。再去看看日志,翻到最后错误代码如下

170702 22:37:41 [ERROR] /usr/local/mysql/bin/mysqld: Can't create/write to file '/var/run/mysqld/mysqld.pid' (Errcode: 13)
170702 22:37:41 [ERROR] Can't start server: can't create PID file: Permission denied(这个文件夹权限被拒,我们改下一下权限)

14.修改权限chown -R mysql /var/run/mysqld 

15.修改权限chgrp -R mysql /var/run/mysqld

16.再启动./bin/mysqld_safe &

17.现在咱们启动客户端./bin/mysql有一个错误提示ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)。意思是连不上mysql.sock。详解:在linux和Unix下面安装mysql会装两个,一个是mysql客户端一个是mysqld服务器。它俩是两个独立的进程,但是它俩需要沟通交换数据,一般都是通过网卡去交换数据,但如果他们都是在本地机localhost,允许用sock文件去交换数据。用sock文件有一个好处就是不用绕网卡了,速度会比走网卡快一点。

18.解决这个问题有两种办法,

第一种:让服务端mysqld满足客户端mysql,ps aux | grep mysql看到mysqld的sock文件放在路径/var/lib/mysql/mysql.sock,我们给客户端mysql设置一个链接,相当于windows下面的快捷方式,代码:ln /var/lib/mysql/mysql.sock /tmp/mysql.sock,然后启动mysql./bin/mysql,恭喜你成功了

第二种:给客户端指定服务端的sock问路径,怎么指定呢。查看帮助:./bin/mysql --help|grep socket这时候你看到是用大-S指定socket路径。我们启动一下试试:./bin/mysql -S /var/lib/mysql/mysql.sock 恭喜你成功了。

提示:默认是没有密码的,如果想改密码请看:修改MySQL数据库密码请戳http://www.cnblogs.com/wangzhaobo/p/7110506.html

Linux配置LNMP环境(三)配置MySQL的更多相关文章

  1. Linux配置LNMP环境(一)配置Nginx

    注意:配置版本nginx-1.12.0,使用虚拟机安装linux.教程中的下载地址可能有变化.注意(在您看本教程之前首先需要对linux的基本操作熟悉) 1.  先cd到/usr/local/src ...

  2. Linux配置LNMP环境(二)配置PHP

    前言:本教程安装的PHP版本php-5.6.30(官方最后更新日期2017-01-19),教程编写日期2017-07-02.本教程中的下载地址是在写教程的时候从官方复制的,时间过长可能会有变化. 安装 ...

  3. Linux配置tomcat (centos配置java环境 tomcat配置篇 总结三)

    ♣下载安装tomcat7 ♣设置启动和关闭 ♣设置用户名和密码 ♣发布java web项目 声明:这篇教程是建立在前两篇教程的基础上的,所以,还没安装工具和jdk,可以先看这个系列的前面两篇(去到文末 ...

  4. 新手配置LNMP环境教程

    回顾一下这几天自己配置LNMP环境踩得坑,希望帮助更多人 前期准备:VMtool.Linux.Nginx.Mysql.PHP.cmake 版本如下:Centos6.nginx1.6.0.mysql5. ...

  5. CentOS 6.5 yum安装配置lnmp服务器(Nginx+PHP+MySQL)

    以下全部转载于  http://blog.csdn.net/lane_l/article/details/20235909 本人于今晚按照该文章使用centos 6.7 64bit安装成功,做个备份, ...

  6. CentOS 6.4安装配置LNMP服务器(Nginx+PHP+MySQL)

    准备篇 1.配置防火墙,开启80端口.3306端口 vi /etc/sysconfig/iptables-A INPUT -m state --state NEW -m tcp -p tcp --dp ...

  7. 8.LNMP环境的配置

    LNMP环境的配置 参照文档:https://oneinstack.com/install/ 安装文件位置:/data/soft: ```yum -y install wget screen pyth ...

  8. linux下Java环境的配置

    linux下Java环境的配置 现在用linux的朋友越来越多了,前几天就有两个朋友问我linux下怎么配置java环境,我想还有很多朋友想了解学习这方面的东西,就写一个完全一点的linux java ...

  9. LNMP笔记:阿里云32位 CentOS 5.4 配置 LNMP环境

    最近比较郁闷的是 WordPress大学 服务器故障,由于诸多原因没及时处理,导致10多天无法访问.倡萌也是刚接触服务器环境配置,维护的确力不从心,没办法排查出错误根源,所以只好重置系统盘,重新配置L ...

随机推荐

  1. Hibernate中调用带有underscore的Column Name

    Hibernate中默认的NamingStrategy不支持调用带有下划线的column name.在hibernate的bean中必须使用camel case.使用ImprovedNamingStr ...

  2. iOS开发常用第三方开源框架 持续更新中...

    键盘管理 TPKeyboardAvoiding IQKeyboardManager(1.2.8) 弹窗HUD MBProgressHUD(0.9.2) SVProgressHUD UIView+Toa ...

  3. 物理CPU 逻辑CPU 核数

    一.概念 ① 物理CPU 实际Server中插槽上的CPU个数 物理cpu数量,可以数不重复的 physical id 有几个 ② 逻辑CPU ③ CPU核数  一块CPU上面能处理数据的芯片组的数量 ...

  4. ovs + kernel datapath 的分片与重组流程

    非VXLAN的收发包调用栈 netdev_frame_hook()      netdev_port_receive()           ovs_vport_receive()           ...

  5. 线程(java课堂笔记)

    1.两种方式的差异 2.线程的生命周期 3.线程控制(线程的方法) 4.线程同步 5.线程同步锁 一. 两种方式的差异 A extends Thread :简单 不能再继承其他类了(Java单继承)同 ...

  6. java数据结构(二叉树)

    Node节点: public class Node { public long data; public String sData; public Node leftChild; public Nod ...

  7. 调试JDK源码时,不能查看变量的值

    前几天本来想以debug模式看一下JDK的源码,进入调试模式时才发现,根本看不到方法里面变量值的情况.为什么呢?JDK现在的版本中,编译过后,去除了里面的调试信息.解决办法是,编译那些类,使其带有调试 ...

  8. ue4打包问题的巧妙解决——二分回退大法!

    昨天突然发生了一件非常恐怖的事--我的ue4项目居然不能打包了!! 大概是这么一回事:  UATHelper: 打包 (Windows (64位)): UnrealBuildTool: ERROR:  ...

  9. java面试基础题(三)

    程序员面试之九阴真经 谈谈final, finally, finalize的区别: final:::修饰符(关键字)如果一个类被声明为final,意味着它不能再派生出新的子类,不能作为父类被继承.因此 ...

  10. Bash提示符

    Bash有四种提示符 1.基本提示符(PS1):即$符号,是默认的基本提示符,当Shell运行在交互模式下时,该提示符会出现在屏幕上,可以设置为其它符号. 显示PS1设置[cb@cb:16:36:23 ...