标签为 Mysql 的文章

MySQL主从复制(Master-Slave)与读写分离(MySQL-Proxy)实践

Mysql作为目前世界上使用最广泛的免费数据库,相信所有从事系统运维的工程师都一定接触过。但在实际的生产环境中,由单台Mysql作为独立的数据库是完全不能满足实际需求的,无论是在安全性,高可用性以及高并发等各个方面。

因此,一般来说都是通过 主从复制(Master-Slave)的方式来同步数据,再通过读写分离(MySQL-Proxy)来提升数据库的并发负载能力 这样的方案来进行部署与实施的。

如下图所示:

下面是我在实际工作过程中所整理的笔记,在此分享出来,以供大家参考。

一、MySQL的安装与配置
具体的安装过程,建议参考我的这一篇文章:http://heylinux.com/archives/993.html
值得一提的是,我的安装过程都是源码包编译安装的,并且所有的配置与数据等都统一规划到了/opt/mysql目录中,因此在一台服务器上安装完成以后,可以将整个mysql目录打包,然后传到其它服务器上解包,便可立即使用。

二、MySQL主从复制
场景描述:
主数据库服务器:192.168.10.130,MySQL已经安装,并且无应用数据。
从数据库服务器:192.168.10.131,MySQL已经安装,并且无应用数据。

2.1 主服务器上进行的操作
启动mysql服务
/opt/mysql/init.d/mysql start

通过命令行登录管理MySQL服务器
/opt/mysql/bin/mysql -uroot -p’new-password’

授权给从数据库服务器192.168.10.131
mysql> GRANT REPLICATION SLAVE ON *.* to ‘rep1’@’192.168.10.131’ identified by ‘password’;

查询主数据库状态
Mysql> show master status;
+——————+———-+————–+——————+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+——————+———-+————–+——————+
| mysql-bin.000005 | 261 | | |
+——————+———-+————–+——————+

记录下 FILE 及 Position 的值,在后面进行从服务器操作的时候需要用到。

2.2 配置从服务器
修改从服务器的配置文件/opt/mysql/etc/my.cnf
将 server-id = 1修改为 server-id = 10,并确保这个ID没有被别的MySQL服务所使用。
阅读全文 »

28 Comments

源码编译安装 MySQL 5.5.x 实践

1.安装cmake
MySQL从5.5版本开始,通过./configure进行编译配置方式已经被取消,取而代之的是cmake工具。
因此,我们首先要在系统中源码编译安装cmake工具。

# wget http://www.cmake.org/files/v2.8/cmake-2.8.4.tar.gz

# tar zxvf cmake-2.8.4.tar.gz

# cd cmake-2.8.4

# ./configure
# make
# make install

2.确保以下所需系统软件包已经被安装
通过 rpm -qa | grep name 的方式验证以下软件包是否已全部安装。
gcc* gcc-c++* autoconf* automake* zlib* libxml* ncurses-devel* libgcrypt* libtool*

如果缺少相关的软件包,可通过yum -y install 的方式在线安装,或直接从系统安装光盘中找到并通过rpm -ivh 的方式安装。

3. 安装前的系统设置
建立mysql安装目录及数据存放目录
# mkdir /opt/mysql
# mkdir /opt/mysql/data

创建用户和用户组
# groupadd mysql
# useradd -g mysql mysql

赋予数据存放目录权限
# chown mysql:mysql -R /opt/mysql/data

4.从configure更换为cmake
我相信大多数人都已经习惯了之前的configure方式,并且所使用的参数也是比较个性化的,换成cmake之后,这一方面会带来不少的麻烦。
还好,MySQL的官方网站提供了二者的参数对照表,我们可以尽可能的保留之前的参数,来编译配置新的MySQL版本。

configure 与 cmake 参数对照指南:
http://forge.mysql.com/wiki/Autotools_to_CMake_Transition_Guide

以我自己为例,之前我一直使用的参数为:
./configure –prefix=/opt/mysql/ \
–sysconfdir=/opt/mysql/etc \
–localstatedir=/opt/mysql/data \
–with-tcp-port=3306 \
–with-unix-socket-path=/tmp/mysqld.sock \
–with-mysqld-user=mysql \
–enable-assembler \
–with-extra-charsets=all \
–enable-thread-safe-client \
–with-big-tables \
–with-readline \
–with-ssl \
–with-embedded-server \
–enable-local-infile \
–with-plugins=partition,innobase,myisammrg

经过与cmake的参数对照之后,去除掉已经被取消的参数(大多数是因为新版本已经默认启用),cmake的参数配置如下:
cmake -DCMAKE_INSTALL_PREFIX=/opt/mysql \
-DSYSCONFDIR=/opt/mysql/etc \
-DMYSQL_DATADIR=/opt/mysql/data \
-DMYSQL_TCP_PORT=3306 \
-DMYSQL_UNIX_ADDR=/tmp/mysqld.sock \
-DMYSQL_USER=mysql \
-DEXTRA_CHARSETS=all \
-DWITH_READLINE=1 \
-DWITH_SSL=system \
-DWITH_EMBEDDED_SERVER=1 \
-DENABLED_LOCAL_INFILE=1 \
-DWITH_INNOBASE_STORAGE_ENGINE=1
阅读全文 »

9 Comments

Nginx0.8.x+PHP5.2.14+Mysql5.5.3在小内存VPS服务器上的安装配置与优化

注:该文档大量参考了 张宴 的两篇原创文章,在此表示由衷的感谢。

两篇文章链接如下:
http://blog.s135.com/post/375/
http://blog.s135.com/nginx_php_v6/

但是,由于我所采用的Nginx,Php,Mysql的版本都要比张宴在第一篇文章中的版本高一些,所以在实际的安装过程中,并非一帆风顺,主要是在编译的参数和配置文件方面出现了一些问题,好在最后都得以解决。因此,我将整个过程记录了下来,以供大家参考。

阅读全文 »

, , , ,

4 Comments

Apache+Mysql+Php+ZendOptimizer+JDK+Tomcat 安装与配置[原创规范]

所需文件的下载地址:
Mysql:http://dev.mysql.com/downloads/mysql/
Apache:http://httpd.apache.org/download.cgi
Php:http://www.php.net/downloads.php
Zlib:http://www.zlib.net/zlib-1.2.3.tar.gz
Freetype:http://sourceforge.net/project/showfiles.php?group_id=3157
Libpng:http://sourceforge.net/search/?type_of_search=soft&type_of_search=soft&words=libpng
Jpeg-6b:http://www.ijg.org/files/jpegsrc.v6b.tar.gz
GD Library:http://www.boutell.com/gd/http/gd-2.0.33.tar.gz
Zend Optimizer:http://www.zend.com/en/products/guard/downloads
JDK:http://java.sun.com/j2se/1.4.2/download.html
Tomcat:http://archive.apache.org/dist/jakarta/tomcat-5/
Tomcat-connectors:http://archive.apache.org/dist/jakarta/tomcat-connectors/jk2/source/

1)      安装配置Mysql (Mysql4.x.xx 与 Mysql5.x.xx 版本皆可)

打开并进入Mysql编译环境:
$ tar xzvf mysql-x.x.xx.tar.gz
$ cd mysql-x.x.xx/

修改编译所需配置文件sql/mysqld.cc 中的最大连接数:
搜索:&max_connections, 0, GET_ULONG, REQUIRED_ARG, 100, 1, 16384, 0, 1,
修改:&max_connections, 0, GET_ULONG, REQUIRED_ARG, 200, 1, 16384, 0, 1,

$ groupadd mysql
$ useradd -g mysql mysql

(如果是Debian或Ubuntu系统的话可能需要)
安装系统默认缺少的curses/termcap 库:
$ apt-cache search curses | grep lib
$ apt-get install libncurses5-dev

$ mkdir -p /opt/mysql/data
$ mkdir -p /opt/mysql/var

$ ./configure –prefix=/opt/mysql –with-mysqld-user=mysql –with-extra-charsets=all –with-unix-socket-path=/opt/mysql/var/mysql.sock –localstatedir=/opt/mysql/data –with-client-ldflags=-all-static –with-mysqld-ldflags=-all-static –enable-assembler
注:–prefix=/opt/mysql 把mysql-x.x.xx指定安装到/opt/mysql目录中;
–with-extra-charsets=all 对多语言的支持;
–with-unix-socket-path=/opt/mysql/var/mysql.sock 这个是指定mysql服务器启动后,联机套接字文件所处的位置和文件名,避免mysql无法启动的情况发生;
–with-mysqld-user=username 这个是让mysql服务器也能让系统中普通用户username也能启动mysql服务器,避免死掉但无法推出的情况;
–localstatedir=/opt/mysql/data 指定数据库文件存放的目录;

$ make
$ make install

待MySQL安装完毕.剩下的就是配置了;
$ cp /opt/mysql/share/mysql/my-medium.cnf /etc/my.cnf

注:将配置文件拷贝到/etc目录下成为my.cnf,大家可以根据自己的需要选择配置文件(配置文件在/opt/mysql/share/mysql/目录下,有my-huge.cnf my-medium.cnf my-large.cnf my-small.cnf这些).

修改mysql各系统文件权限与属主,以避免启动时造成错误;
$ chmod 755 /opt/mysql/var/             设置/opt/mysql/var的目录权限为755
$ chown -R mysql:mysql /opt/mysql/      把/opt/mysql目录归属到mysql这个用户下

创建MySQL的授权表;
$ /opt/mysql/bin/mysql_install_db –user=mysql

配置并启动Mysql服务;
$ /opt/mysql/bin/mysqld_safe &
$ cp /opt/mysql/share/mysql/mysql.server /etc/init.d/mysqld
$ cd /opt/mysql/libexec
$ cp mysqld mysqld.old
$ strip mysqld
$ ln -s /opt/mysql/bin/mysql /usr/bin/mysql
$ ln -s /opt/mysql/bin/mysqladmin /usr/sbin/mysqladmin

$ netstat -atln                           查看3306端口是否打开
$ /etc/init.d/mysqld restart              如果重启mysql顺利则说明mysql安装成功
$ mysqladmin -u root password 123456      设置mysql的root密码

$ mysql -uroot –p123456                   使用root用户进入mysql命令行
mysql>use mysql;
mysql>delete from user where password=””;删除用于本机匿名连接的空密码帐号
mysql>flush privileges;
mysql>quit;

进入/etc目录下的rc2.d rc3.d rc4.d rc5.d 目录建立开机自启动服务的软链接文件;
$ ln -s ../init.d/mysqld S20mysql
进入/etc目录下的rc0.d rc1.d rc6.d 目录建立关机自停止服务的软链接文件;
$ ln -s ../init.d/mysqld K20mysql

2)      安装配置Apache (Apache2.x.x 版本)

打开并进入Apache编译环境:
$ tar xzvf httpd-2.x.x.tar.gz
$ cd httpd-2.x.x/

$ ./configure –prefix=/opt/apache –enable-so –enable-rewrite –enable-cgi –with-config-file-path=/opt/apache/conf –enable-track-vars –with-mpm=worker
注:–prefix=/opt/apache 指定安装到/opt/apache目录中;
–enable-cgi 支持CGI;
–with-config-file-path=/opt/apache/conf 指定把配制文件放在/opt/apache/conf目录中;
–enable参数告诉设置脚本,我们需要启动so和rewrite模块,so模块是用来提供DSO支持的apache核心模块,而rewrite模块则是用意实现地址重写的模块,由于rewrite模块需要DBM支持,如果在初次安装时没有编译进apache,以后需要用到时需要重新编译整个apache才可以实现。

$ make
$ make install
修改配置文件/opt/apache/conf/httpd.conf:

ServerName 127.0.0.1:80

<IfModule dir_module>
DirectoryIndex index.html index.html.var index.htm index.php
</IfModule>

# If the AddEncoding directives above are commented-out, then you
# probably should define those extensions to indicate media types:
AddType application/x-compress .Z
AddType application/x-gzip .gz .tgz
AddType application/x-httpd-php .php
AddType application/x-httpd-php-source .phps

$ cp /opt/apache/bin/apachectl /etc/init.d/apachectl
$ ln -s /opt/apache/bin/apachectl /usr/bin/apachectl

进入/etc目录下的rc2.d rc3.d rc4.d rc5.d 目录建立开机自启动服务的软链接文件;
$ ln -s ../init.d/apachectl S20apache
进入/etc目录下的rc0.d rc1.d rc6.d 目录建立关机自停止服务的软链接文件;
$ ln -s ../init.d/apachectl K20apache

$ apachectl start
在浏览器的地址栏中输入商用通IP,若看到“It works!”字样或 Apache羽毛页面则说明安装成功!

3)      安装Php以及相关常用组件 (Php4.x.x 与 Php5.x.x 版本皆可)

编译安装GD库相关套件:
zlib: 进入解压后的zlib目录并执行以下命令:
$ ./configure
$ make
$ make install
freetype:进入解压后的freetype目录并执行以下命令:
$ ./configure –prefix=/usr/local/freetype
$ make
$ make install
libpng:进入解压后的libpng目录并执行以下命令:
$ ./configure
$ make
$ make install
jpeg-6b:进入解压后的jpeg-6b目录并执行以下命令:
$ mkdir -p /usr/local/jpeg/bin
$ mkdir /usr/local/jpeg/lib
$ mkdir /usr/local/jpeg/include
$ mkdir -p /usr/local/jpeg/man/man1
$ ./configure –prefix=/usr/local/jpeg –enable-shared –enable-static
$ make
$ make install
GD Library:进入解压后的gd目录并执行以下命令:
$ ./configure –prefix=/usr/local/gd –with-jpeg=/usr/local/jpeg –with-freetype=/usr/local/freetype –with-png –with-zlib
$ make
$ make install

打开并进入Php编译环境:
$ tar xzvf php-x.x.x.tar.gz
$ cd php-x.x.x/

(如果是Debian或Ubuntu系统的话可能需要)
安装系统默认缺少的lex 组件:
$ apt-get install flex

编译并安装php:
$ ./configure –prefix=/opt/php –with-apxs2=/opt/apache/bin/apxs –with-gd=/usr/local/gd –enable-gd –enable-gd-native-ttf –with-jpeg-dir=/usr/local/jpeg –with-png –with-ttf –with-zlib –with-freetype-dir=/usr/local/freetype –enable-magic-quotes –with-mysql=/opt/mysql –with-mysql-sock=/opt/mysql/var/mysql.sock –with-iconv –with-mbstring –enable-mbstring –enable-track-vars –enable-force-cgi-redirect –enable-ftp –with-config-file-path=/opt/php/etc –with-pear=/opt/php/pear –enable-sockets –with-mail –with-xml

$ make
$ make install

$ cp php-x.x.x/php.ini-dist /opt/php/etc/php.ini

修改配置文件/opt/php/etc/php.ini:
register_globals = On

然后编写php测试页info.php:内容如下:
<?php
phpinfo();
?>

查看/opt/apache/conf/httpd.conf文件,看是否存在语句(如果安装的Php5):
LoadModule php5_module        modules/libphp5.so
如果存在,即说明apache已经成功加载了php模块;

$ apachectl restart
将info.php放置到/opt/apache/htdocs 目录下;
$ chmod 755 info.php
在浏览器中能在该页面中看到php的信息则说明安装成功!
注:启用了SELinux的FC或RedHat会提示权限问题并导致Php无法正常工作,禁用SELinux后重启系统即可解决问题。

4)      安装配置ZendOptimizer (各个版本皆可)
$ tar xzvf ZendOptimizer-x.x.x-linux-x-i386.tar.gz
$ cd ZendOptimizer-x.x.x/
$ ./install.sh
接着依照安装向导的提示信息完成整个安装配置过程;

此刻,LAMP环境已经安装完毕,不需要Tomcat服务的话到这里就算结束了。

5)      安装配置JDK ( j2sdk-1.4.2.xx 版本皆可)

$ chmod a+x j2sdk-1_4_2_09-linux-i586.bin (本文中安装的版本为 1.4.2_09)
$ ./j2sdk-1_4_2_09-linux-i586.bin
安装后会生成文件夹j2sdk1.4.2_09,将文件夹j2sdk1.4.2_09移动(或复制)到你想要存放的JDK的位置(本文中是/opt/j2sdk1.4.2_09/);
接下来编辑/etc/profile文件加入JDK环境变量,在文件末尾处加入以下内容:

$ vi /etc/profile

export JAVA_HOME=/opt/j2sdk1.4.2_09
export CLASSPATH=.:$CLASSPATH:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
export PATH=$PATH:$JAVA_HOME/bin
export JRE_HOME=$JAVA_HOME/jre

$ source /etc/profile
这样可以使配置文件的内容立刻生效;

$ set
在这里你可以看见当前所有的环境变量;

$ java –version
如果JDK配置正确的话,运行上面的命令将会出现JDK的相应版本。

6)      安装配置Tomcat以及相关组件 (jakarta-tomcat-5.x.xx版本皆可)
$ tar xzfv jakarta-tomcat-5.0.28.tar.gz   (本文安装的版本是:jakarta-tomcat-5.0.28)

$ cp -rf jakarta-tomcat-5.0.28 /opt/tomcat
$ cd /opt/tomcat/

现在来测试一下tomcat是否安装成功:

$ ./bin/startup.sh      启动tomcat服务
访问http://127.0.0.1:8080/ 看能否看到tomcat的默认页面,能看到说明tomcat服务已经在运行了。

$ ./bin/shutdown.sh 停止tomcat服务
注意观察停止服务的时候有无报错信息。
开始安装jakarta-tomcat-connectors-jk2,用来整合apache和tomcat,编译生成的mod_jk2.so模块被apache加载之后,就能将不属于自己的请求转发给tomcat:
$ tar xzfv jakarta-tomcat-connectors-jk2-2.0.4-src.tar.gz

$ cd jakarta-tomcat-connectors-jk2-2.0.4-src/jk/native2/

$ ./configure –with-apxs2=/home/www/apache/bin/apxs
$ make

$ cd ../build/jk2/apache2/
$ /opt/apache/bin/apxs -n jk2 -i mod_jk2.so   (将mod_jk2.so添加到apache2的modules中)

上面就完成了Tomcat和Connectors的安装.接下来进行与Apache的整合.

Tomcat与Apache的整合:
$ cd /opt/apache/conf/

vi httpd.conf

编辑配置文件在其中加入这个模块,保存退出;
LoadModule jk2_module modules/mod_jk2.so

然后在这个目录新建一文件workers2.properties
$ vi workers2.properties

[channel.socket: localhost:8009]
port=8009
host=localhost
[ajp13: localhost:8009]
channel=channel.socket: localhost:8009
[uri:/*.jsp]
worker=ajp13: localhost:8009
[uri:/examples/*.jsp]
worker=ajp13: localhost:8009

$ cd /opt/tomcat/conf/

vi server.xml
找到其中的<Host>中的<Contest>项,修改相关参数如下,保存退出;
<Context path=”” docBase=”/opt/apache/htdocs” debug=”0″ reloadable=”true” crossContext=”true”/>

$ /opt/tomcat/bin/startup.sh
$ apachectl restart
重启Apache和Tomcat后即可查看到整合后的效果。

参考资料:
《RedHatAS4下Apache2+MySQL+Php+Tomcat整合及虚拟主机配置》http://bbs.chinaunix.net/viewthread.php?tid=770898
《Linux+Apache+Mysql+PHP典型配置》 http://www.5ilinux.com/blog/archives/000013.html
《Debian+Apache2+MySQL5+PHP5+GD》http://www.pmal.net/viewthread.php?tid=8849

, , , , ,

No Comments