源码安装的优点,编译安装过程,可以设定参数按照需求增加功能,进行安装,并且可以指定安装的版本,可以指定安装路径,灵活性比较大。
源码包和RPM包区别
安装之前的区别:概念上的区别;
安装之后的区别:安装位置不同;源码包安装更加灵活
RPM包安装位置 :
RPM包安装的服务可以使用系统服务管理(启动,关闭重启动)命令service来管理,例如RPM包安装的apache的启动方法是:
/etc/rc.d/init.d/httpd start
service httpd start(红帽专有的,不是红帽linux的只能用上面命令启动)
这些安装位置是在写rpm包时已经决定好了 | |
/etc/ | 配置文件安装目录 |
/usr/bin/ | 可执行的命令安装目录 |
/usr/lib/ | 程序所使用的数据库保存位置 |
/usr/share/doc/ | 基本的软件使用手册保存位置 |
/usr/share/man/ | 帮助文档保存位置 |
源码包安装位置 :
一般是 /usr/local/软件名/ 软件名可自定义 。
源码包安装的服务则不能被服务管理命令管理,因为安装路径不同,没有专有的名字。所以只能用绝对路径进行服务的管理,如:/usr/local/apache2/bin/apachectl start
Nginx源码包管理
准备好编译环境:编译器gcc、make,否则会报错。
yum -y install gcc make zlib-devel pcre pcre-devel openssl-devel
- gcc:编译工具,编译单个文件
- make:工具可以看成是一个智能的批处理工具,通过调用makefile文件中用户指定的命令来进行编译和链接的。(将这种高级语言写的代码编译成二进制语言)
- pcre:支持正则表达式
- zlib-devel:有些应用依赖于这个库才能正常运行,因此需要安装zlib-devel
- openssl-devel :某些库文件等跟开发相关的东西。
流程:
1.官网下载nginx源码包(此处以nginx-1.16.1为例)。通常,源码包以或的压缩格式提供:.tar.gz .tar.xz
wget http://nginx.org/download/nginx-1.16.1.tar.gz
2.解压 nginx源码包:
tar xzf nginx-1.16.1.tar.gz
3.进入解压后的Nginx目录,进行配置:
/tmp/nginx-1.24.0/configure --prefix=/usr/local/nginx --user=alan --group=alan
软件配置与检查:
- 定义需要的功能选项 :指定安装路径: --prefix=/usr/local/nginx ;指定启动用户: --user=alan ;指定组: --group=alan
- 检测系统环境(编译器gcc、make等)是否符合安装要求(报错则检查环境)
- 把定义好的 功能选项 和 检测系统环境的信息 都写入Makefile文件,用于后续的编辑
4. 进入nginx目录下,执行编译命令 :
make
#输入echo $? 检验是否出错
make :编译(这个命令是操作当前所在位置):按Makefile文件编译,产生可执行的文件。但是这个文件在当前目录中
如果以上报错了,make clean清空临时文件即可,因为还没有真正的写入文件
make install安装完成(这个命令是操作当前所在位置,它才是真正的写入文件)
5. 编译完成后,安装Nginx :
make install
按Makefile定义的文件路径安装,将产生的可执行文件,安装到合适的位置,相当于拷贝
6. 安装完成后,启动Nginx服务:
/usr/local/nginx/sbin/nginx
#注意关闭防火墙
systemctl stop firewalld
setenforce 0
直接用systemctl命令启动nginx失败了,是因为nginx还没添加到系统服务里.
开启服务:/usr/local/nginx/sbin/nginx
查看服务: ps aux | grep nginx
关闭服务:
# 1. 立即停止Nginx服务
/usr/local/nginx/sbin/nginx -s stop
# 2.完成当前任务后停止
/usr/local/nginx/sbin/nginx -s quit
# 3.杀死Nginx进程
killall nginx
7.检验:网页输入ip
安装mysql
1.编译环境:
关闭防火墙,删除mariadb
#下载好源码包:https://downloads.mysql.com/archives/community/
#libaio 包的作用是为了支持同步I/O,对于数据库之类的系统特别重要
yum install -y libaio
#CMake是一个跨平台的安装(编译)工具
yum install -y cmake
#安装依赖
yum install -y libaio libaio-devel bison bison-devel zlib-devel openssl openssl-devel ncurses ncurses-devel libsurl-devel boost boost-devel lsof gcc gcc-c++ make pcre-devel cmake kernel-devel kernel-headers perl
2.mysql源码包
#创建mysql用户:-r:表示mysql用户是系统用户,不可用于登录系统
groupadd mysql
useradd -r -g mysql mysql
#新建MySQL的安装目录
mkdir /usr/local/mysql
#新建MySQL的数据存储目录
mkdir /usr/local/mysql/data
#解压:
tar -zxvf mysql-boost-5.7.27.tar.gz
3.配置文件:编译/安装
#1.进入mysql文件
cd 到解压文件
#2.编译配置
cmake . \
-DWITH_BOOST=boost/boost_1_59_0/ \
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
-DMYSQL_DATADIR=/usr/local/mysql/data \
-DMYSQL_UNIX_ADDR=/var/lib/mysql/mysql.sock \
-DDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_general_ci \
-DWITH_EXTRA_CHARSETS=all \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_FEDERATED_STORAGE_ENGINE=1 \
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
-DWITHOUT_EXAMPLE_STORAGE_ENGINE=1 \
-DWITH_ZLIB=bundled \
-DWITH_SSL=system \
-DENABLED_LOCAL_INFILE=1 \
-DWITH_EMBEDDED_SERVER=1 \
-DENABLE_DOWNLOADS=1 \
-DDOWNLOAD_BOOST=1 \
-DWITH_DEBUG=0
########################################################
cmake . \
-DWITH_BOOST=./boost/boost_1_59_0/ \ #5.7.27 必须要用到这个版本的boost,下载时有集成了boost的源码
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql \ #mysql的安装目录
-DMYSQL_DATADIR=/usr/local/mysql/data \ #mysql数据的存放位置
-DMYSQL_UNIX_ADDR=/var/lib/mysql/mysql.sock \ #sock文件存放的位置
-DDEFAULT_CHARSET=utf8 \ #默认字符集为utf8
-DDEFAULT_COLLATION=utf8_general_ci \
-DWITH_EXTRA_CHARSETS=all \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \ #是否编译innodb存储引擎
-DWITH_FEDERATED_STORAGE_ENGINE=1 \
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
-DWITHOUT_EXAMPLE_STORAGE_ENGINE=1 \
-DWITH_ZLIB=bundled \
-DWITH_SSL=system \
-DENABLED_LOCAL_INFILE=1 \ #是否支持本地的导入支持,1表示支持
-DWITH_EMBEDDED_SERVER=1 \
-DENABLE_DOWNLOADS=1 \
-DDOWNLOAD_BOOST=1 \ cmake编译时,还需要boost这个主键(注意boost版本)
-DWITH_DEBUG=0
#3.开始编译【此处时间比较长,约半小时,耐心等待】
make
#4.开始安装
make install
#重新编译时,需要清除旧的对象文件和缓存信息。
# make clean/make clean all
# rm -f CMakeCache.txt
# rm -rf /etc/my.cnf
4.设置权限,初始化数据库,拿到随机密码
chown -R mysql.mysql /usr/local/mysql
#初始化数据库:mysql/bin/mysqld
./bin/mysqld --initialize --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data/
#拿到随机密码: [Note] A temporary password is generated for root@localhost: bxK-EydiO8we
5.把启动脚本放到开机初始化目录,启动服务
#复制mysql服务启动脚本
cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld
#启动MySQL服务
service mysqld start
service mysqld status
service mysqld stop
#登录mysql
/usr/local/mysql/bin/mysql -u root -pbxK-EydiO8we