标签:blackhole sql error sage 改变 set use 5.7 centos7
本文中Linux
命令使用的大部分是绝对路径(若没有前面有相应的目录切换命令)安装时可以不考虑路径问题
源码存放目录:\usr\src\
软件安装目录:\usr\local\软件名称
这里需要说明的是源码存放源代码的位置,安装过程可以指定,软件运行时跑的是软件安装的代码
相应的最新的源码包可以在下列网址中找到
ngnix
http://nginx.org/download/
mysql
https://www.mysql.com/downloads/
php
http://php.net/downloads.php
cmake(MySQL编译工具)
https://cmake.org/download/
boost(MySQL编译工具)
http://nchc.dl.sourceforge.net/project/boost/boost/1.59.0/boost_1_59_0.tar.gz
编译工具及库文件(yum
安装)
yum install -y apr* autoconf automake bison bzip2 bzip2* cloog-ppl compat* cpp curl curl-devel fontconfig fontconfig-devel freetype freetype* freetype-devel gcc gcc-c++ gtk+-devel gd gettext gettext-devel glibc kernel kernel-headers keyutils keyutils-libs-devel krb5-devel libcom_err-devel libpng libpng-devel libjpeg* libsepol-devel libselinux-devel libstdc++-devel libtool* libgomp libxml2 libxml2-devel libXpm* libxml* libtiff libtiff* make mpfr ncurses* ntp openssl openssl-devel patch pcre-devel perl php-common php-gd policycoreutils telnet t1lib t1lib* nasm nasm* wget zlib-develyum install -y apr* autoconf automake bison bzip2 bzip2* cloog-ppl compat* cpp curl curl-devel fontconfig fontconfig-devel freetype freetype* freetype-devel gcc gcc-c++ gtk+-devel gd gettext gettext-devel glibc kernel kernel-headers keyutils keyutils-libs-devel krb5-devel libcom_err-devel libpng libpng-devel libjpeg* libsepol-devel libselinux-devel libstdc++-devel libtool* libgomp libxml2 libxml2-devel libXpm* libxml* libtiff libtiff* make mpfr ncurses* ntp openssl openssl-devel patch pcre-devel perl php-common php-gd policycoreutils telnet t1lib t1lib* nasm nasm* wget zlib-devel
创建软件存放目录
mkdir -p /usr/local/cmake
编译安装
tar -xzvf cmake-3.8.0.tar.gz
cd cmake-3.8.0/
./configure --prefix=/usr/local/cmake
make && make install
echo ‘export PATH=$PATH:/usr/local/cmake/bin‘ >> /etc/profile
source /etc/profile
tar xzvf boost_1_59_0.tar.gz
cd boost_1_59_0/
./bootstrap.sh
./b2 install
需要说明的是,这里Boost
的安装可以不指定目录(不进行相关目录的创建),一些配置参数可以通过./b2 --help
命令看到
这里说明一下,默认存放位置是/usr/local/
下;库文件存放在/usr/local/bin
;头文件存放到/usr/local/include
创建MySQL用户和用户组
groupadd mysql
useradd -g mysql mysql -s /bin/false
创建软件存放目录
mkdir -p /usr/local/mysql
MySQL数据存放目录
mkdir -p /var/mysql/data
创建日志存放目录
mkdir -p /usr/local/mysql/log
对数据存放目录授予权限
chown -R mysql:mysql /var/mysql/
对日志目录授予权限
chown -R mysql:mysql /usr/local/mysql/log
tar -zxvf mysql-boost-5.7.18.tar.gz
cd mysql-5.7.18
cmake \
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
-DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \
-DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_ARCHIVE_STORAGE_ENGINE=1 \
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
-DMYSQL_DATADIR=/var/mysql/data\
-DMYSQL_TCP_PORT=3306\
-DENABLE_DOWNLOADS=1
make && make install
选项 | 含义 |
---|---|
DCMAKE_INSTALL_PREFIX | 安装目录 |
DMYSQL_UNIX_ADDR | sock文件路径 |
DDEFAULT_CHARSET | 默认字符集 |
DWITH_INNOBASE_STORAGE_ENGINE | 安装INNODB |
DWITH_ARCHIVE_STORAGE_ENGINE | 存储引擎可用值 |
DWITH_BLACKHOLE_STORAGE_ENGINE | 存储引擎可用值 |
DMYSQL_DATADIR | 设置MySQL数据存放目录 |
DMYSQL_TCP_PORT | MySQL监听端口 |
其中MyISAM,MERGE,MEMORYMERGE,CSV是默认编译生成的不需要明确指定
更多的参数含义可以参考MySQL官网文章
需要注意的是5.7版本的软件安装目录与之前版本不太一样,具体介绍
目录 | 目录内容 |
---|---|
bin | MySQL服务端,客户端可执行文件 |
docs | MySQL文档格式信息 |
include | 包含的头文件 |
lib | 库文件 |
man | MySQL手册信息 |
mysql-test | MySQL测试文件 |
share | 支持文件 |
support-files | MySQL启动脚本 |
创建MySQL配置文件
cd /usr/local/mysql
vim my.cnf
将如下配置项写入my.cnf中(这里需要说明的是MySQL 5.7.18
之后安装目录中就没有my.cnf)
[mysqld]
basedir=/usr/local/mysql
datadir=/var/mysql/data
port=3306
socket=/usr/local/mysql/tmp/mysql.sock
log-error=/usr/local/mysql/log/mysqld.log
tmpdir=/tmp
max_allowed_packet=32M
#bind-address=127.0.0.1
[client]
port=3306
socket=/usr/local/mysql/tmp/mysql.sock
default-character-set=UTF8
[manager]
port=3306
socket=/usr/local/mysql/tmp/mysql.sock
pid-file=/usr/local/mysql/tmp/manager.pid
default-mysqld-path=/usr/local/mysql/bin/mysqld.bin
开启MySQL和进行设置
cd /usr/local/mysql/bin
./mysqld --initialize --user=mysql --basedir=/usr/local/mysql --datadir=/var/mysql/data
./mysql_ssl_rsa_setup --datadir=/var/mysql/data
./mysqld_safe --user=mysql &
cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld
/etc/init.d/mysqld start
需要注意的是在执行完./mysqld --initialize
命令后会分配一个默认的密码在日志文件中,查看密码
cat /usr/local/mysql/log/mysqld.log
详细选项参数说明可以使用如下命令
./mysqld --verbose --help
也可以查阅官网MySQL初始化文档
修改root密码
mysql -u root -p密码
mysql> SET PASSWORD FOR ‘root‘@‘localhost‘ = PASSWORD(‘newpass‘);
如果需要设置MySQL了可以远程连接,可以进行如下设置
mysql -uroot -p密码
GRANT ALL ON *.* TO ‘root‘@‘%‘ IDENTIFIED BY ‘密码‘ WITH GRANT OPTION;
FLUSH PRIVILEGES;
这里值得注意的是配置远程登录首先需要注释掉配置文件中bind-address=ip
这句话,才可以通过设置表权限进行远程登录的控制
设置环境变量方便使用SQL
命令
echo ‘export PATH = $PATH:/usr/local/mysql/bin‘
make[2]: *** [unittest/gunit/CMakeFiles/merge_small_tests-t.dir/merge_small_tests.cc.o] Error 4
make[1]: *** [unittest/gunit/CMakeFiles/merge_small_tests-t.dir/all] Error 2
make: *** [all] Error 2
错误产生原因:swap
分区不够
解决办法:
[root@VM_6_37_centos ~]# dd if=/dev/zero of=/swapfile bs=1k count=2048000
[root@VM_6_37_centos ~]# mkswap /swapfile
[root@VM_6_37_centos ~]# swapon /swapfile[root@web_1 ~]# dd if=/dev/zero of=/swapfile bs=1k count=2048000
[root@VM_6_37_centos ~]# mkswap /swapfile
[root@VM_6_37_centos ~]# swapon /swapfile
Can‘t connect to local MySQL server through socket ‘/tmp/mysql.sock‘ (2)
错误产生原因:没有启动MySQL
解决办法:开启MySQL
/usr/local/mysql/support-files/mysql.server start
mysql: [Warning] Using a password on the command line interface can be insecure.
ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: YES)
错误产生原因:密码错误
解决办法:查看日志文件,找到初始密码进行登录(日志文件目录在配置文件制定)
cat /usr/local/mysql/log/mysqld.log
这里需要说明,安装启动MySQL遇到错误提示可能是相同的,我们可以根据自己的情况进行查明
groupadd www
useradd -g www www -s /bin/bash/false
cd /usr/src/
tar -zxvf nginx-1.12.0.tar.gz
cd nginx-1.12.0/
./configure --prefix=/usr/local/ngnix --user=www --group=www --with-http_stub_status_module --with_http_ssl_module --with-http_gzip_static_module --with-threads
make && make install
./configure
选项参数可以通过./configure --help
查看
可以查阅官网文档
创建网站根目录并修改用户权限
mkdir /var/www
chown www:www /var/www
进入配置文件目录cd /usr/local/ngnix/conf/
cd /usr/local/ngnix/conf/ngnix.conf
vim ngnix.conf
将网站的根目录修改为/var/www
vim /usr/local/ngnix/cong/ngnix.conf
#在http的server中修改localtion的root属性
http{
server{
localtion / {
root /var/www
}
}
}
更多的配置项可以参考官网文档
添加Ngnix
的sbin
目录到环境变量
echo "export PATH = $PATH:/usr/local/ngnix/sbin" >> /etc/profile
source /etc/profile
启动Ngnix
ngnix
需要说明的是Ngnix
有相应的选项参数,可以通过ngnix -h
进行查看
Usage: nginx [-?hvVtTq] [-s signal] [-c filename] [-p prefix] [-g directives]
Options:
-?,-h : this help
-v : show version and exit
-V : show version and configure options then exit
-t : test configuration and exit
-T : test configuration, dump it and exit
-q : suppress non-error messages during configuration testing
-s signal : send signal to a master process: stop, quit, reopen, reload
-p prefix : set prefix path (default: /usr/local/ngnix/)
-c filename : set configuration file (default: conf/nginx.conf)
-g directives : set global directives out of configuration file
值得注意的是-s
选项的参数,有如下四种
名称 | 含义 |
---|---|
stop | 快速关掉ngnix进程 |
quit | 优雅关掉ngnix进程即等待其它请求结束后在关闭ngnix进程 |
reload | 重新加载配置文件 |
reopen | 重新打开日志文件 |
到此ngnix
安装结束
cd /usr/src
tar -zxvf php-7.1.4.tar.gz
cd php-7.1.4
./configure --prefix=/usr/local/php --with-config-file-path=/usr/local/php/etc --with-mysqli=/usr/local/mysql/bin/mysql_config --with-mysql-sock=/tmp/mysql.sock --with-pdo-mysql=/usr/local/mysql --with-iconv --enable-libxml --enable-xml --enable-bcmath --enable-shmop --enable-sysvsem --enable-inline-optimization --enable-opcache --enable-mbregex --enable-fpm --enable-mbstring --enable-ftp --enable-gd-native-ttf --with-openssl --enable-pcntl --enable-sockets --with-xmlrpc --enable-zip --enable-soap --without-pear --with-gettext --enable-session --with-mcrypt --with-curl --enable-ctype --enable-mysqlnd
make && make install
值得注意的是:./configure
后面的选项可以通过./configure --help
命令进行详细查看,需要注意的是php-fpm
模块时必须安装的
从编译后的源码包中复制配置文件到安装目录
cp /usr/src/php-7.1.4/php.ini-production /usr/local/php/etc/php.ini
编辑php-fpm
的配置文件
cp /usr/local/php/etc/php-fpm.conf.default /usr/local/php/etc/php-fpm.conf
vim /usr/local/php/etc/php-fpm.conf
#取消前面的分号
pid = run/php-fpm.pid
cp /usr/local/php/etc/php-fpm.d/www.conf.default /usr/local/php/etc/php-fpm.d/www.conf
#改变用户组及用户
user = www
group = www
启动php-fpm
/usr/local/sbin/php-fpm
编辑Ngnix
配置文件ngnix.conf
取消如下显示内容的注释
vim /usr/local/ngnix/conf/ngnix.conf
http{
server{
# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
location ~ \.php$ {
root /var/www;#修改网站根目录
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;
include fastcgi_params;
}
}
}
标签:blackhole sql error sage 改变 set use 5.7 centos7
原文地址:http://www.cnblogs.com/xiaohuihui520/p/6786268.html