`
alvinqq
  • 浏览: 185858 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

Linux上安装Mysql

阅读更多
Cache Server Configuration Manual

1、Operation System Requirement:
RedHat Linux AS 4 update 4
2、Package Installation:
1) Editors
2) Server Configuration Tools
3) Development Tools
4) Administration Tools
3、Language:
English (US)
4、Application Software:
1)Software:  Squid-3.0.STABLE8加密版本 Mysql for Linux 5.0.45
2)Download the software files from Files server (192.168.65.180) 
5、Mysql Configuration
1) 安装路径
/usr/local/mysql
   2) 添加用户和组
[Root@shell]# groupadd mysql 添加组命令
[Root@shell]# useradd mysql -g mysql 添加用户命令
4)  Mysql编译参数
将mysql-5.0.45.tar.gz上传到服务器/root文件,首先解压mysql-5.0.45.tar.gz文件,输入以下命令
[Root@shell]#tar –zvxf mysql-5.0.45.tar.gz
[Root@shell]cd mysql-5.0.45 然后执行下面命令
 
[Shell]# ./configure --prefix=/usr/local/mysql --enable-thread-safe-client --with-charset=utf8 --with-extra-charsets=all --with-mysqld-user=mysql --enable-large-files --with-big-tables --with-unix-socket-path=/tmp/mysql.sock --localstatedir=/var/lib/ --with-plugins=all

5) 编译与安装
[Root@shell]#make
[Root@shell]# make install
6) 修改权限
[Root@shell]# chown -R mysql:mysql /usr/local/mysql
7) 初始化数据库、修改权限
[Root@shell]#./scripts/mysql_install_db  --datadir=/var/lib/mysql
chown -R mysql:mysql /var/lib/mysql
8)复制并修改Mysql系统配置文件
[Root@shell]#cp -arf support-files/my-medium.cnf /etc/my.cnf
vi /etc/my.cnf
[mysqld]
skip-name-resolve   //这一选项可以消除MySQL进行DNS解析的时间
#skip-federated //注释掉
#log-bin=mysql-bin  //注释掉mysql-bin
set-variable = max_connections=60000 设置连接
9)添加mysql到Service ,并设置随机自动运行Mysql
[Root@shell]#cp support-files/mysql.server /etc/rc.d/init.d/mysqld
接着把它的属性改为“x”(executable,可执行)
[Root@shell]#chmod +x /etc/init.d/mysqld
[Root@shell]#chown mysql.mysql /etc/init.d/mysqld
修改/etc/init.d/mysqld (第46、47行)
basedir=/usr/local/mysql
datadir=/var/lib/mysql

10) 最后,运行chkconfig把MySQL添加到你系统的启动服务组里面去。
[Root@shell]#/sbin/chkconfig --add mysqld
11) 服务启动
[Root@shell]# service mysqld start
12) 更改mysql管理员密码
[Root@shell]#mysqladmin -u root password ‘cdnhub2008’


权限分配:
mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'Gcdn.idcsea.com' WITH GRANT OPTION;
   其中两个账户有相同的用户名monty和密码some_pass。两个账户均为超级用户账户,具有完全的权限可以做任何事情。一个账户 ('monty'@'localhost')只用于从本机连接时。另一个账户('monty'@'%')可用于从其它主机连接。


mysql> GRANT RELOAD,PROCESS ON *.* TO 'admin'@'localhost';
该账户只用于从本机连接。授予了RELOAD和PROCESS管理权限。这些权限允许admin用户执行mysqladmin reload、mysqladmin refresh和mysqladmin flush-xxx命令,以及mysqladmin processlist。未授予访问数据库的权限。你可以通过GRANT语句添加此类权限。

mysql> GRANT USAGE ON *.* TO 'dummy'@'localhost';
    一个账户有用户名dummy,没有密码。该账户只用于从本机连接。未授予权限。通过GRANT语句中的USAGE权限,你可以创建账户而不授予任何权限。它可以将所有全局权限设为'N'。假定你将在以后将具体权限授予该账户。
flush privileges;
6、Squid Database configuration
[Shell]# mysql –u root –p
Mysql> create database squid;
Mysql> use squid;
Mysql> create table traffic (
date datetime default '0000-00-00 00:00:00',
cachemsec int,
ip_addr varchar(15),
tag varchar(28),
httpcode int,
bytes bigint(20) ,
method varchar(5),
url varchar(255),
user char(8),
timeout varchar(12),
hierstr varchar(10),
hierhost varchar(15),
contenttype varchar(30),
ereq varchar(20),


erep varchar(20)
);
Mysql> GRANT ALL ON squid.* TO squid@localhost IDENTIFIED BY 'squidsar';
Mysql>GRANT ALL ON squid.* TO squid@127.0.0.1 IDENTIFIED BY 'squidsar';
Mysql>flush privileges;
注:数据库名:squid,表名:traffic,用户名squid,密码:squidsar(2008-04-08更新)


7、JAVA Configuration
1)、安装路径
/usr/local/java/
   2)、安装方法
     从文件服务器上传 jdk-6u4-linux-i586.bin和mysql-connector-java-5.1.5-bin.jar至/usr/local
[Root@shell]# sh jdk-6u4-linux-i586.bin  弹出协议,大概按下7次空格键后,输入yes,会在/usr/local下生成一个jdk1.6.0_04目录
   3)、将mysql-connector-java-5.1.5-bin.jar文件移动到jdk1.6.0_04
      [Root@shell]#mv mysql-connector-java-5.1.5-bin.jar jdk1.6.0_04/lib
   4)、将文件移动到java下
      [Root@shell]# mkdir /usr/loca/java
     [Root@shell]# mv /usr/local/jdk1.6.0_04 /usr/local/java
   5)、配置环境变量
      [Root@shell]#vi /root/.bash_profile   在文件尾部加入以下信息
 export LANG= en
export LC_ALL= C
export JAVA_HOME=/usr/local/java/jdk1.6.0_04
export JAVA_BIN=$JAVA_HOME/bin
export CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar:$JAVA_HOME/lib/mysql-connector-java-5.1.5-bin.jar
export PATH=$JAVA_HOME/bin:$PATH

   6、重新登录Linux,新的java环境立即生效
8、SSL Support Configuration
1)、下载openssl
http://www.openssl.org/source/openssl-0.9.8i.tar.gz或从192.168.65.180中取得
2)、解压安装
[Root@shell]#tar -zvxf openssl-0.9.8i.tar.gz
[Root@shell]#cd openssl-0.9.8i
[Root@shell]#./config --prefix=/usr/local/openssl
     [Root@shell]# make
     [Root@shell]# make install
     [Root@shell]#
3)、产生key
[Root@shell]#cd /usr/local/openssl/ssl
    [Root@shell]#openssl genrsa -out privkey.pem 2048
   4)、产生证书
[Root@shell]#openssl req -new -keyout privkey.pem -nodes -x509 -days 1095 -out cacert.pem
Country Name (2 letter code) [GB]:CN

State or Province Name (full name) [Berkshire]:Beijing
Locality Name (eg, city) [Newbury]: Beijing
Organization Name (eg, company) [My Company Ltd]:CDNHUB System Co,.Ltd.
Organizational Unit Name (eg, section) []:noc
Common Name (eg, your name or your server's hostname) []:ssl-gw-bjcnc-60.cdnhub.com(视节点名称而改变)
Email Address []:noc@cdnhub.com
5)、配置squid:
      将以下内容插入到squid的配置文件sqiud.conf中(可通过CDNMS系统来生成)
#SSL Support
https_port 443 vhost vport=443 cert=/usr/local/openssl/ssl/cacert.pem key=/usr/local/openssl/ssl/privkey.pem
sslproxy_flags DONT_VERIFY_PEER

9、Squid Configuration
1) 安装路径
/usr/local/squid   从文件服务器将文件上传至/usr/local/目录下
   2) 添加用户和组
[Root@shell]# groupadd squid 添加组命令
[Root@shell]# useradd squid –g squid  添加用户命令
3)初始化目录级权限
[Root@shell]#mkdir /cachelog/squid
[Root@shell]# mkdir /cachelog/squid/logs
[Root@shell]# mkdir /cachelog/squid/logs/backups
[Root@shell]#chown –R squid:squid /cache*
   4) 解压文件
[Root@shell]# tar –zvxf squid.3.0.8.tar.gz
5) 修改权限
[Root@shell]#chown –R squid:squid /usr/local/squid
6) 生成配置文件(squid.conf)
     手上上传配置文件或通过CDNMS生成(如果通过CDNMS生成,需先进行第10点操作完成后,方可远程生成配置文件)
7)初始化Cache目录
[Root@shell]#/usr/local/squid/sbin/squid –z
8) 启动squid服务
[Root@shell]# ulimit –Hn 32768
[Root@shell]# /usr/local/squid/sbin/squid –D –s &


10、CDNCS-Configuration
1)修改IPTABLE:将新的节点服务器IP增加至/root/ipfw.sh文件中,并运行/root/ipfw.sh文件
2)修改路由表走向,CDNCS服务器分别配有电信,网通,香港IP地址各一个,默认路由是电信出口,如果增加的节点服务器为网通或国外节点,需要个修改/root/route.sh文件,将其节点IP手动增加到路由表,并手工执行路由增加命令
3)授权节点服务器对CDNCS中的mysql有写入的权限:
进入mysql服务器,执行以下命令:
[root@Shell ~]# mysql -u root -p
Enter password:
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 284 to server version: 5.0.45

Type 'help;' or '\h' for help. Type '\c' to clear the buffer.

mysql> use mysql
Database changed
mysql> GRANT INSERT ON COUNT_CDN_SAR.* TO squid@x.x.x.x IDENTIFIED BY 'squidcount';
mysql>GRANT SELECT,UPDATE ON cdnhub_cdnms.CACHE_SERVER_STATUES TO squid@x.x.x.x IDENTIFIED BY 'squidcount';
mysql>exit
备注:x.x.x.x 为节点服务器的IP地址

4)修改随机启动文件,将防火墙配置和squid随服务器一起启动
[root@Shell ~]#vi /etc/rc.local
添加以下内容
/bin/sh /root/ipfw.sh &
ulimit –Hn 32768
/usr/local/squid/sbin/squid –D –s &

11、Remote Admin and Traffic Statistic Configuration
1)安装目录
将cdnhub文件夹上传到/usr/local下
2)修改该目录所以.sh文件,增加可执行权限。
[Root@shell]#chmod +x *.sh  (分别进入各目录执行)
4)修改rmi目录中的rmi_server.properties,替换IP、IPENCRYPT(这个值需要在CDNMS加添服务器后取得),修改完成后,启动rmi监控程序:sh server.sh &
5)修改sar目录中的COUNT_CDN_SAR_DB.properties中的jdbc:mysql://220.231.181.244(适合电信节点),如果是网通节点,需将该IP换成58.251.130.222
6)修改sar目录中的Read_Stop_domain_ip_traffic.properties的localAddress=210.83.80.217(节点服务器IP)和domain_ip_traffic_last_data_time=2008-11-05 17\:53\:00(修改DNS时的时间,也就是第一次使用时间)
修改完以上配置文件后,启动流量上传程序文件:sh start_traffic.sh &



12、Auto Split AccessLog and upload to FTPSRV
1)上传文件:将文件Split_Access_log_preday_predomain.sh  ftplog.sh  uploadaccesslog.sh上传到节点服务器/cachelog/squid/logs/backups/
2)授于执行权限:chmod +x /cachelog/squid/logs/backups/*.sh
13、Crontab Configuration
[Root@shell]# crontab –e
添加以下内容:
#-----------SyncTime------------------------------
0 0 * * * /usr/local/cdnhub/system/synctime.sh
#-----------Backup Access Log --------------------
0 0 * * * /usr/local/cdnhub/system/access-log-backup.sh
#----------Split AccessLog and upload AccessLog----
1 1 * * * /cachelog/squid/logs/backups/uploadaccesslog.sh
#---------- Java program monitoring-------
*/10 * * * * /usr/local/cdnhub/system/Monitorjava.sh
:wq保存退出


14、Firewall setting
1)Firewall文件存放路径:/root/ipfw.sh
2)Firewall文件内容:
#!/bin/sh
/sbin/iptables -F
# SSH service access list
/sbin/iptables -A INPUT -i eth0 -p tcp -s 10.92.254.0/24 --dport 22 -j ACCEPT
/sbin/iptables -A INPUT -i eth0 -p tcp -s 10.92.16.0/24 --dport 22 -j ACCEPT
/sbin/iptables -A INPUT -i eth0 -p tcp -s 192.168.65.0/24 --dport 22 -j ACCEPT
/sbin/iptables -A INPUT -i eth0 -p tcp -s 220.232.159.0/24 --dport 22 -j ACCEPT
/sbin/iptables -A INPUT -i eth0 -p tcp -s 220.231.182.0/24 --dport 22 -j ACCEPT
/sbin/iptables -A INPUT -i eth0 -p tcp -s 220.231.183.0/24 --dport 22 -j ACCEPT
/sbin/iptables -A INPUT -i eth0 -p tcp -s 58.251.1.0/24 --dport 22 -j ACCEPT
/sbin/iptables -A INPUT -i eth0 -p tcp -s 58.251.50.0/24 --dport 22 -j ACCEPT
/sbin/iptables -A INPUT -i eth0 -p tcp -s 61.145.165.0/24 --dport 22 -j ACCEPT
/sbin/iptables -A INPUT -i eth0 -p tcp -s 222.126.128.0/17 --dport 22 -j ACCEPT
/sbin/iptables -A INPUT -i eth0 -p tcp -s 0.0.0.0/0 --dport 22 -j DROP
# http and https and other service access list
/sbin/iptables -A INPUT -i eth0 -p tcp -m multiport -s 0.0.0.0/0 --dport 80,443 -j ACCEPT
#SNMP service only for mrtg.cdnhub.com
/sbin/iptables -A INPUT -i eth0 -p udp -s 220.231.181.242/32 --dport 161 -j ACCEPT
/sbin/iptables -A INPUT -i eth0 -p udp -s 0.0.0.0/0 --dport 161 -j DROP
#java for Squid configuration
/sbin/iptables -A INPUT -i eth0 -s 220.231.182.0/29 -j ACCEPT
/sbin/iptables -A INPUT -i eth0 -s 220.231.181.243/32 -j ACCEPT
/sbin/iptables -A INPUT -i eth0 -s 220.231.181.244/32 -j ACCEPT

/sbin/iptables -A INPUT -p tcp -m multiport --sport 20,21,25,53,22,123,80,443 -j ACCEPT
/sbin/iptables -A INPUT -p udp -m multiport --sport 20,21,25,53,22,123,80,443 -j ACCEPT
/sbin/iptables -A INPUT -p tcp -s 0.0.0.0/0 --sport 1024:65535 -j ACCEPT
/sbin/iptables -A INPUT -p udp -s 0.0.0.0/0 --sport 1024:65535 -j ACCEPT
#Accept ICMP
/sbin/iptables -A INPUT -p icmp --icmp-type any -j ACCEPT

#Drop
/sbin/iptables -A INPUT -i eth0 -j DROP


注:ethX需视节点服务器的网卡名称来决定,使用ifconfig可以查看到所以网卡的名称

15、SNMP Installation and configuration
1)所需要文件:net-snmp-5.1.2-11.EL4.7.i386.rpm  net-snmp-libs-5.1.2-11.EL4.7.i386.rpm
2)安装方法:
[Root@shell]# rpm –ivh net-snmp-libs-5.1.2-11.EL4.7.i386.rpm
[Root@shell]# rpm –ivh net-snmp-5.1.2-11.EL4.7.i386.rpm
3)修改snmpd.conf文件
[Root@shell]# vi /etc/snmp/snmpd.conf
将第41行号的public改cdnhub
在56行后面增加一行,内容为:view    systemview    included   .1
将123行第一个字符#号去掉
保存并退出:wq
4)重新启动SNMPD 服务:service snmpd restart
5)在mrtg.cdnhub.com添加新的监控条目
分享到:
评论

相关推荐

    Linux下安装mysql

    ### Linux 下安装 MySQL 在 Linux 系统中安装 MySQL 数据库是一项常见的任务,尤其是在搭建 Web 服务器或开发环境中。本文将详细介绍如何在 Linux 系统上安装 MySQL,并提供相关的配置和管理指南。 #### 准备工作 ...

    Linux下安装Mysql

    而“Linux mysql安装教程”则意味着我们将遵循一套步骤来完成安装过程。 在标签中,“mysql rpm包”再次强调了我们使用RPM格式的包来安装MySQL,“安装教程”意味着我们将提供详细的步骤指导。 在提供的压缩包子...

    linux下安装mysql服务器

    Linux 下安装 MySQL 服务器 Linux 下安装 MySQL 服务器是指在 Linux 操作系统中安装和配置 MySQL 数据库服务器的过程。MySQL 是一种关系型数据库管理系统,广泛应用于 Web 应用程序中。 知识点: 1. 安装 MySQL ...

    Linux下安装MYSQL

    ### Linux下安装MySQL 在Linux环境下安装MySQL是一个常见的任务,对于开发者、系统管理员以及数据库管理员而言至关重要。本文将详细介绍在Linux环境下安装MySQL的过程,并提供一些实用的技巧与建议。 #### 准备...

    linux下安装mysql

    ### Linux 下安装 MySQL 在 Linux 系统中安装 MySQL 数据库是一项常见的任务,尤其是在搭建 Web 服务器时。本文将详细介绍如何在 CentOS 操作系统上安装 MySQL 5.5,并进行必要的配置。 #### 一、安装 cmake 在...

    linux下安装MySQL

    MySQL-server-community-5.1.60-1.rhel4.i386.rpm,linux下安装MySQL的安装包

    Linux 下 安装 mysql

    ### Linux下安装MySQL详细步骤与知识点 #### 一、引言 在Linux环境下安装MySQL数据库是一项常见的任务,尤其是在CentOS这样的服务器操作系统上。本文将详细介绍如何在CentOS系统上安装MySQL,并解决安装过程中可能...

    linux一键安装mysql

    总结来说,"Linux一键安装MySQL"是一个通过自动化脚本简化MySQL安装和配置过程的方法,极大地节省了系统管理员的时间和精力。正确执行上述步骤,你就能在Linux环境中快速部署并开始使用MySQL数据库。不过,值得注意...

    Linux上安装MySQL

    ### Linux上安装MySQL 在Linux环境下安装MySQL是一个常见的任务,特别是对于那些希望在服务器环境中部署数据库应用程序的用户来说。本文将详细介绍如何在Linux系统中安装MySQL,并解决在安装过程中可能遇到的一些...

    Linux下安装MySQL.docx

    Linux 下安装 MySQL Linux 是一个开源的操作系统, MySQL 是一个开源的关系数据库管理系统。在 Linux 系统中安装 MySQL 是一个非常重要的步骤。本文将一步步指导您如何在 Linux 系统中安装 MySQL。 查找以前是否...

    linux上安装mysql

    周么在家里安装mysql,一直报错,后来找到原因是安装的版本不正确,没有正确卸载,对应版本无法安装,最后卸载好了,再安装。。。

    在Linux下安装Mysql(非root)

    Linux 下非 Root 用户安装 Mysql 在 Linux 操作系统中安装 Mysql 数据库可以通过多种方式实现,包括使用源代码编译安装和二进制安装。对于非 Root 用户来说,安装 Mysql 可能会遇到一些权限问题,但是通过正确的...

    Linux下安装MySQL.pdf

    【Linux下安装MySQL】 在Linux操作系统中安装MySQL数据库是一个必要的步骤,特别是在开发和管理Web应用程序时。本教程将详述如何在Linux环境下卸载旧版本的MySQL,以及如何正确安装和配置新版本的MySQL。 首先,...

    Linux下安装mySQL

    ### Linux下安装MySQL知识点详述 #### 一、下载与准备RPM包 在Linux环境下安装MySQL,首先需要获取MySQL的RPM包。RPM(Red Hat Package Manager)是一种用于管理软件包的工具,广泛应用于Red Hat Enterprise Linux...

Global site tag (gtag.js) - Google Analytics