1. vm下安装Ubuntu
1)下载镜像ubuntu-15.04-desktop-amd64.iso
http://yunpan.cn/cF5dwV6zw33ef 访问密码 ecba(个人分享在360网盘)
2) 安装完成后,第一个处理问题就是中文转换--语言支持--更改用户的语言为中文
3)虚拟机和主机交互需要安装linux的vmtools。
 
2. mysql
1)根据上面步骤就可以有一个基础的linux环境。也很方便我们拷贝和下载文件了。
2)直接通过命令安装比较简单,如下
sudo apt-get install mysql-server
apt-get isntall mysql-client
sudo apt-get install libmysqlclient-dev
 
3)但是这样mysql 的路径都会是默认地址,和公司目录一样,我们更希望我们的应用在一个目录下,这样我们就需要编译安装。
 

1. 安装环境:
Ubuntu 15.04
MySQL-5.6.21.tar.gz

2. 安装必备的工具(保证mysql安装的基础环境)
sudo apt-get install make bison g++ build-essential libncurses5-dev cmake

3. 添加组合用户 设置安装目录权限
sudo groupadd mysql(未做)
sudo useradd –g mysql mysql –s /bin/false #创建用户mysql并加入到mysql组,不允许mysql用户直接登录系统(未做)

说明:我的软件安装目录: /home/test/alidata/soft/
sudo mkdir –p /home/test/alidata/soft/mysql #创建Mysql安装目录
sudo mkdir -p /home/test/alidata/soft/mysql/data
sudo mkdir -p /home/test/alidata/soft/mysql/log

sudo chown -R mysql:mysql /usr/local/mysql/data(未做)
sudo chown -R mysql:mysql /usr/local/mysql(未做)

4. 编译安装mysql

4.1 获取源码包
cd //home/test/alidata/soft/
sudo wget http://cdn.mysql.com/Downloads/MySQL-5.6/mysql-5.6.23.tar.gz

4.2 解压mysql源码包
sudo tar –zxvf mysql-5.6.23.tar.gz

5. 编译配置(先cmake设置配置, make 编译 , make install 拷贝到对应目录)
cd mysql-5.6.23
1)sudo cmake -DCMAKE_INSTALL_PREFIX=/home/test/alidata/soft/mysql -DSYSCONFDIR=/etc -DMYSQL_UNIX_ADDR=/tmp/mysql.sock -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DEXTRA_CHARSETS=all -DWITH_MYISAM_STORAGE_ENGINE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_MEMORY_STORAGE_ENGINE=1 -DWITH_READLINE=1 -DENABLED_LOCAL_INFILE=1 -DMYSQL_DATADIR=/home/test/alidata/soft/mysql/data -DWITH_DEBUG=0

说明:

-DCMAKE_INSTALL_PREFIX:mysql需要安装的目录(需要自定义)

-DMYSQL_DATADIR:mysql数据需要存放的目录(需要自定义)

注意事项:
重新编译时,需要清除旧的对象文件和缓存信息。
# make clean
# rm -f CMakeCache.txt
# rm -rf /etc/my.cnf

2)sudo make -j4 #-j数字 表示以多核心运行

时间最长,耐心等待,没有报错就是ok,有报错根据提示安装需要的应用
3)sudo make install

6. 相关配置
6.1 配置开机启动
sudo chmod +w /home/test/alidata/soft/mysql(增加权限)
sudo cp ./support-files/my-default.cnf /etc/my.cnf
sudo cp ./support-files/mysql.server /etc/init.d/mysqld
sudo chmod 755 /etc/init.d/mysqld

6.2 常用命令软连接,设置环境变量
sudo ln -s /home/test/alidata/soft/mysql/lib/libmysqlclient.so.18 /usr/lib/libmysqlclient.so.18
sudo ln -s /home/test/alidata/soft/mysql /usr/bin
sudo ln -s /home/test/alidata/soft/mysql/bin/mysqladmin /usr/bin

6.3 初始化数据库

sudo /home/test/alidata/soft/mysql/scripts/mysql_install_db --defaults-file=/etc/my.cnf --basedir=/home/test/alidata/soft/mysql --datadir=/home/test/alidata/soft/mysql/data --user=test

说明:网上会默认的增加mysql用户,使用MySQL用户来作为mysql的主用户处理。我们已自己新建的test用户。

7. 启动mysql服务试一试
sudo /etc/init.d/mysqld start

有问题看日志(重要):

See "systemctl status mysqld.service" and "journalctl -xe" for details

最后添加用户:

adduser mysql

说明:启动的时候发现还是有地方会需要mysql用户,所以又加上了。于是就ok了。呵呵呵。不过好处是使用test来运行mysql没有之前碰到的各种权限问题。

8. 启动成功后创建root用户的密码(不要忘记哦)
mysqladmin -u root password

再次设置密码mysqladmin -u root password -p root

9. 成功后使用一下
mysql -uroot -p

需要添加环境变量

vim /etc/profile

export PATH=/home/test/alidata/soft/mysql/bin:$PATH

source /etc/profile

10. 开机启动mysql

http://www.2cto.com/database/201312/265018.html

sudo update-rc.d -f mysql.server defaults(提示找不到mysql.server命令就使用下面的命令)

sudo update-rc.d -f mysqld defaults(或者)(在第6步赋值为mysqld所以这里使用的是该命令)

取消开机启动

sudo update-rc.d -f mysql.server remove

关于cmake命令详解:

注释:
我把安装路径放在了/usr/local/mysql,也就是默认的路径,data放在/usr/local/mysql/data/下,sock文件放到/usr/local/mysql/mysqld.sock
一些参数如下:根据需要选择吧。
CMAKE_INSTALL_PREFIX:指定MySQL程序的安装目录,默认/usr/local/mysql
DEFAULT_CHARSET:指定服务器默认字符集,默认latin1
DEFAULT_COLLATION:指定服务器默认的校对规则,默认latin1_general_ci
ENABLED_LOCAL_INFILE:指定是否允许本地执行LOAD DATA INFILE,默认OFF
WITH_COMMENT:指定编译备注信息
WITH_xxx_STORAGE_ENGINE:指定静态编译到mysql的存储引擎,MyISAM,MERGE,MEMBER以及CSV四种引擎默认即被编译至服务器,不需要特别指定。
WITHOUT_xxx_STORAGE_ENGINE:指定不编译的存储引擎
SYSCONFDIR:初始化参数文件目录
MYSQL_DATADIR:数据文件目录
MYSQL_TCP_PORT:服务端口号,默认3306
MYSQL_UNIX_ADDR:socket文件路径,默认/tmp/mysql.sock

ubuntu环境下lnmp环境搭建(1)之Mysql的更多相关文章

  1. Ubuntu系统下lnmp环境搭建和Nginx多站点配置

    最近需要使用Ubuntu作为服务器搭建Lnmp环境,顺便将操作过程写下来,与大家分享.如有不足之处,欢迎大家提出不同意见.(本文默认读者已经熟悉相关linux命令的使用,比如创建文件和文件夹,编辑文件 ...

  2. ubuntu环境下lnmp环境搭建(3)之Php

    1.lnmp详细  http://www.discuz.net/thread-3513107-1-1.html 2. 到php目录 http://blog.aboutc.net/linux/65/co ...

  3. ubuntu环境下lnmp环境搭建(2)之Nginx

    1. ubuntu编译安装nginx http://www.cnblogs.com/zhangjun516/archive/2013/02/03/2890990.html 1. 手动编译安装 Ngin ...

  4. linux环境下测试环境搭建

    一.linux环境下测试环境搭建过程简述: 1.前端后台代码未分离情况下: 主要步骤为:安装jdk,安装mysql,安装tomcat,将项目代码部署到tomcat/webapps/下. 2.前端后台代 ...

  5. windows环境下mosquitto环境搭建与mqtt测试

    https://blog.csdn.net/pgpanda/article/details/51800865 工作需求,自己在windows下搭建了一个mosquitto环境测试mqtt 话不多说,直 ...

  6. linux环境下 python环境import找不到自定义的模块

    linux环境下 python环境import找不到自定义的模块 问题现象: Linux环境中自定义的模块swport,import swport 出错.swport模块在/root/sw/目录下. ...

  7. Windows环境下完全手工配置Apache、MySQL和PHP

    现在LAMP(Linux.Apache.MySQL.PHP/Perl/Python的简称)已经很流行了.在Windows下也有类似的,比如 WAMP(Apache, MySQL, PHP on Win ...

  8. Linux系统下LNMP一键搭建Linux、PHP、MySQL环境(适合新手搭建linux下的web生成环境)

    一. 首先要解释一下,什么是LNMP,LNMP起源于LAMP,LAMP是Linux+Apache+Mysql/MariaDB+Perl/PHP/Python的缩写,这里将Web服务端的Apache替换 ...

  9. Ubuntu系统下QEMU环境搭建

    (这篇文章是在搭建QEMU环境时,在网上找到了一些教程资料,并在实际操作中遇到的一些问题的整理) 下载Linux内核 下载内核有两种方法,一种是用git直接下载内核代码树,方便后面的内核开发.另一种是 ...

随机推荐

  1. JavaScript学习日志(五):DOM

    一,基本定义 DOM是针对HTML和XML文档的API,根据W3C的HTML DOM标准,html文档中所以内容(无论是元素还是标签还是注释还是元素属性)都是节点. 二,Node类型:每一个节点都含有 ...

  2. tomcat配置单项HTTPS协议

    1.进入到jdk下的bin目录     1)进入cmd窗口,cd进入目录: 2)找到JDK安装bin目录,shift+右击打开命令窗口: 3)如果配置类环境变量,在任意cmd命令窗口都可以: 2.输入 ...

  3. linux每日一练:Enable multithreading to use std::thread: Operation not permitted问题解决

    linux每日一练:Enable multithreading to use std::thread: Operation not permitted问题解决 在linux在需要使用c++11时会遇到 ...

  4. JQuery 相关用法和操作

    01-JQuery 基础语法: 1.使用JQuery必须先导入JQuery.x.x.xjs文件. 2.JQuery中的选择器: $(选择器).函数() ① $是JQuery的缩写,既可以使用JQuer ...

  5. 团队作业8——第二次项目冲刺(Beta阶段)--第六天

    一.Daily Scrum Meeting照片 二.燃尽图 三.项目进展 学号 成员 贡献比 201421123001 廖婷婷 16% 201421123002 翁珊 16% 201421123004 ...

  6. 201521123093 java 第五周学习总结

    1. 本周学习总结 1.1 尝试使用思维导图总结有关多态与接口的知识点. 1.2 可选:使用常规方法总结其他上课内容. 答:接口:1.所有的默认方法都是public abstract; 2.属性都是p ...

  7. 201521123049 《JAVA程序设计》 第1周学习总结

    1. 本章学习总结 1.认识了新的一门计算机编程语言JAVA: 2.JAVA的编写与C语言类似,都是不能利用指针进行编写: 3.在实验课上初步认识JAVA并利用JAVA进行简单的编程,在实践上得到进一 ...

  8. Emacs操作指南

  9. .net core 使用Redis的发布订阅

    Redis是一个性能非常强劲的内存数据库,它一般是作为缓存来使用,但是他不仅仅可以用来作为缓存,比如著名的分布式框架dubbo就可以用Redis来做服务注册中心.接下来介绍一下.net core 使用 ...

  10. 2017年9月19日 JavaScript语法操作

    关于JavaScript个人还是觉得比较有意思的 {在</html>后面写或者在</body>前面写(必须紧贴</body>)} <script> va ...