centos 搭建web平台

centos 查询是否安装apache
rpm -qa httpd

出现类似 httpd-2.2.15-47.el6.centos.4.x86_64  ,说明已安装

yum -y install httpd    // 安装apache

yum -y install php   // 安装php  php 5.3.3-46

yum -y install mysql  // mysql (5.1.73)

yum -y install mysql-server (5.1.73)
yum -y install php-mysql (5.3.3-46)

安装apache扩展:
yum -y install httpd-manual mod_ssl mod_perl mod_auth_mysql

安装php扩展:
yum -y install php-gd php-xml php-mbstring php-ldap php-pear php-xmlrpc

yum -y install libjpeg* php-imap php-ldap php-odbc php-pear php-xml php-xmlrpc php-mbstring php-mcrypt php-bcmath php-mhash libmcrypt

安装mysql的扩展:
yum -y install mysql-connector-odbc mysql-devel libdbi-dbd-mysql

设置Apache服务的启动级别
chkconfig --levels 235 httpd on
Apache是一个服务,所以,可以通过设置服务的启动级别来让它启动

info:

1、验证是否安装成功
现在打开http://ip地址

2、安装目录介绍
Apache默认将网站的根目录指向/var/www/html 目录
默认的主配置文件是/etc/httpd/conf/httpd.conf
配置存储在的/etc/httpd/conf.d/目录

apache的配置文件是/etc/httpd/conf下
modules放在/usr/lib/httpd下

php的配置文件在/etc/php.d/下和/etc/php.ini
php的modules放在/usr/lib/php/modules下

mysql的配置配置文件在 /etc/my.cnf #
/sbin/chkconfig httpd on [设置apache服务器httpd服务开机启动] or chkconfig --levels 235 httpd on #/sbin/service httpd start [启动httpd服务,与开机启动无关] or /etc/init.d/httpd start #/sbin/service mysqld start [启动mysqld服务,与开机启动无关] note: sbin目录本身在系统path环境中,可省略 mysql_secure_installation //或者 /usr/bin/mysqladmin -u root password 'new-password' /usr/bin/mysqladmin -u root -h iZ259588ge4Z password 'new-password'

chkconfig 命令详解 设置开机启动服务:http://www.jb51.net/LINUXjishu/86331.html

java相关配置:

查看是否安装java ,

java -version  

yum list installed | grep java

若有自带安装的openjdk,先卸载掉:

yum -y remove java-1.7.0-openjdk*

yum -y remove tzdata-java.noarch

安装open jdk1.7或以后版本或sun jdk 解压:

openjdk与sun jdk区别参考:http://www.zhihu.com/question/19646618

Oracle的项目发布经理Joe Darcy在OSCON 2011上对两者关系的介绍也证实了OpenJDK 7和Oracle JDK 7在程序上是非常接近的,两者共用了大量相同的代码: http://zhidao.baidu.com/link?url=g7aZwk4DV3iCvDi1fo6w9aIlbBnpxBB-do85u8B1wvTC4NdZSb26RCRE4BCJ_BK6V3fP5aAKxdnX2ODSPP1OnWv2PmKyt-LtSxPyvdkdsV_

查找jdk包

yum -y list java*

yum -y install java-1.7.0-openjdk*

下载sunjdk上传然后安装配置

export JAVA_HOME=/usr/share/jdk1.6.0_14
export PATH=$JAVA_HOME/bin:$PATH
export CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar 

参考: http://www.linuxidc.com/Linux/2012-09/70780.htm

        http://www.centoscn.com/image-text/install/2014/0827/3585.html

        http://www.cnblogs.com/samcn/archive/2011/03/16/1986248.html

note:

noarch是no architecture的缩写,说明这个包可以在各个不同的cpu上使用

/etc/profile : 在登录时,操作系统定制用户环境时使用的第一个文件 ,此文件为系统的每个用户设置环境信息,当用户第一次登录时,该文件被执行.

/etc /environment : 在登录时操作系统使用的第二个文件, 系统在读取你自己的profile前,设置环境文件的环境变量。

~/.profile :  在登录时用到的第三个文件 是.profile文件,每个用户都可使用该文件输入专用于自己使用的shell信息,当用户登录时,该文件仅仅执行一次!默认情况下,他设置一些环境变量,执行用户的.bashrc文件。

/etc/bashrc : 为每一个运行bash shell的用户执行此文件.当bash shell被打开时,该文件被读取.

~/.bashrc : 该文件包含专用于你的bash shell的bash信息,当登录时以及每次打开新的shell时,该该文件被读取。

安装tomcat:

yum安装tomcat6

yum -y install tomcat6 tomcat6-webapps tomcat6-admin-webapps tomcat6-docs-webapp tomcat6-javadoc

yum安装tomcat会自动安装相关的软件,如jre环境等,因此不需要单独安装jre。

yum安装后的tomcat目录说明:

配置文件目录:/etc/tomcat6

安装程序主目录:/var/lib/tomcat6/

在Centos使用yum安装后,Tomcat相关的目录都已采用符号链接到/usr/share/tomcat6目录,包含webapps等,这很方便我们配置管理
[root@tomcattest tomcat6]# ll /usr/share/tomcat6
总用量 4
drwxr-xr-x. 2 root root   4096 10月 19 00:44 bin
lrwxrwxrwx. 1 root tomcat   12 10月 19 00:44 conf ->/etc/tomcat6
lrwxrwxrwx. 1 root root     23 10月 19 00:44 lib ->/usr/share/java/tomcat6
lrwxrwxrwx. 1 root root     16 10月 19 00:44 logs ->/var/log/tomcat6
lrwxrwxrwx. 1 root root     23 10月 19 00:44 temp ->/var/cache/tomcat6/temp
lrwxrwxrwx. 1 root root     24 10月 19 00:44 webapps ->/var/lib/tomcat6/webapps
lrwxrwxrwx. 1 root root     23 10月 19 00:44 work ->/var/cache/tomcat6/work

 修改端口8080为80:
需80端口未被占用,可以使用netstat -nat查看80端口是否在使用。
a)修改vi /etc/tomcat6/server.xml文件的如下字段中的8080为80

<Connector port="8080" protocol="HTTP/1.1"

               connectionTimeout="20000"

               redirectPort="8443" />
b)由于在Centos6中,系统不允许tomcat用户使用1024以下的端口,因此还需修改vi /etc/tomcat6/tomcat6.conf
找到CONNECTOR_PORT="8080"并注释掉,新增如下两行:
TOMCAT_USER="root"
CONNECTOR_PORT="80"
注:这样做的安全性有待验证
 
c)使用命令service tomcat6 restart 重启tomcat服务。以后访问页面就可以只需要输入IP或者主机名即可,而不再需要加端口号。
或者有可用版本的tomcat7
yum list available tomcat*

#yum install tomcat tomcat-webapps tomcat-admin-webapps ...

service tomcat start  //启动tomcat7 或者执行 bin/startup.sh

Tomcat7的安装目录位于/usr/local/tomcat7

使用下载压缩版的tomcat7

参考: http://lcbk.net/tomcat/1407.html

 tomcat 配置apr

apache整合tomcat

1.通过ajp proxy

2.通过apache jk modules , jk通过ajp协议通信

 1.直接通过http-proxy
    1.1.  编辑/etc/httpd/conf/httpd.conf在最后追加
    ProxyPass /tomcat http://www.evcharge.cc:8080/
    ProxyPass /tom http://www.qq.com/

但是这时需要注意:
1.load proxy module应该已去掉注释
2.不能再随意的使用相对路径,(页面css,js文件等)
因为此时路径不再相对于tomcat内部的路径,而是相对于 http://www.evcharge.cc
3.注意每次更改配置文件后重启apache     # service httpd restart

    1.2 附加:ProxyPassReverse
    ProxyPass /tomcat http://www.evcharge.cc:8080            (http://xx.com:8080/ 这里最后加/或者不加/ 我试过header都一样)
    ProxyPassReverse /tomcat http://www.evcharge.cc:8080
    使用反向代理:
    效果同上,一样需要注意相对路径改变的问题
    Apache 反向代理只做 HTTP 透明转发,因此,Tomcat 那边,如果使用 servelet API 获取 request url, server info,等等,都是 Tomcat 的

可以在页面内用base标签指定相对路径的基准url:
<head>
<base href="http://www.w3school.com.cn/i/" />
</head>
base解释:
http://www.w3school.com.cn/html5/html5_base.asp
http://www.w3school.com.cn/tags/tag_base.asp

2.通过ajp
    2.1     编辑/etc/httpd/conf/httpd.conf在最后追加
    ProxyPass /tomcat ajp://www.evcharge.cc:8009/

note:
1.同样注意相对路径的改变,其它同上
2.tomcat的(/etc/tomcat/server.xml)ajp 要启用,且端口号同这里配置的如:8009.

    2.2 附加:ProxyPassReverse
    ProxyPass /tomcat http://www.evcharge.cc:8080/
    ProxyPassReverse /tomcat http://www.evcharge.cc:8080/
    效果同上,一样会改变原本的相对路径(有人说ProxyPassReverse不支持ajp协议,待议(我没发现问题))

3.负载均衡
    通过一个页面来监控集群运行的状态,并做一些简单的维护设置
    http://localhost:8080/balancer-manager/?b=example&s=http&w=server1

    ProxyPass / balancer://example/
    <Proxy balancer://example/>
        BalancerMember http://server1:8080/
        BalancerMember http://server2:8080/
        BalancerMember http://server3:8080/
    </Proxy>

    同上:也可以使用ajp 代理:
    ProxyPass / balancer://example/
    <Proxy balancer://example/>
        BalancerMember ajp://server1:8009/
        BalancerMember ajp://server2:8089/
        BalancerMember ajp://server3:8099/
    </Proxy>
    (尝试失败.)

    ProxyPass /special-area http://special.example.com/ smax=5 max=10
    ProxyPass / balancer://mycluster stickysession=jsessionid nofailover=On
    <Proxy balancer://mycluster>
    BalancerMember http://1.2.3.4:8009
    BalancerMember http://1.2.3.5:8009 smax=10
    # Less powerful server, don't send as many requests there
    BalancerMember http://1.2.3.6:8009 smax=1 loadfactor=20
    </Proxy>

    (注意代理负载均衡 在apache2.2之后才支持)
    相关参数参考:
    http://shiningray.cn/proxypass-directive-in-apache.html
    http://blog.sina.com.cn/s/blog_4cb531010100pkrp.html
    http://tototo163.blog.163.com/blog/static/51555072012114111734967/

    集群参考:
    http://www.cnblogs.com/atyou/archive/2013/05/24/3097078.html


注意ProxyPass /aa  bburl
bburl的地址的灵活性,我们可以用 公网ip, 可以用配置解析好的域名,
 可以用127.0.0.1/localhost,也可以用内网ip如: 10.1.1.16
 比如阿里云的服务器集群,内网流量之间的转发是不收费的,公网流量则收费


ProxyPass 命令:
使用 ! 匹配不使用代理的目录
ProxyPass /tom/images !
ProxyPass /tom/css !
ProxyPass /tom/js !
ProxyPass /tom http://localhost:8080/

ProxyPassReverse 指令
说明: 调整由反向代理服务器发送的HTTP回应头中的URL
例子:
ProxyPass a.com/aa   b.com/bb.php   // 访问a.com/aa时后台转发到b.com/bb.php处理
此时b.com/bb.php 中有一个重定向到b.com/cc.php
不使用reverse
则访问a.com/aa时后台转发到b.com/bb.php,重定向到cc.php时,http header里显示cc.php的host为b.com/cc.php

使用reverse
ProxyPassRevers a.com/aa b.com/bb.php
则访问a.com/aa时后台转发到b.com/bb.php,重定向到cc.php时,http header里显示cc.php的host为a.com/aa/cc.php
(额,测试没发现)


4.jk
参考:
http://www.ibm.com/developerworks/cn/opensource/os-lo-apache-tomcat/
http://www.ntu.edu.sg/home/ehchua/programming/howto/ApachePlusTomcat_HowTo.html

5.使用URL rewrite,也就是对于指定格式的 URL,转发给某个 Tomcat 的网址。
这里所说的指定格式,是指 Apache 所使用的正则表达式,
通俗地将,是一种类似 * 的一种比较高级通配符。这种方法不需要下在额外的文件,只需要配置 Apache


参考:
http://httpd.apache.org/docs/2.2/mod/mod_proxy.html#proxypass
http://httpd.apache.org/docs/2.0/mod/mod_proxy.html
http://blog.csdn.net/xxfigo/article/details/11180673
http://stackoverflow.com/questions/13550121/apache-tomcat-proxypass-and-proxypassreverse

1.

/etc/httpd/conf/httpd.conf 启用 proxy_modules  去掉前面的 # 号注释
LoadModule proxy_module modules/mod_proxy.so
LoadModule proxy_ajp_module modules/mod_proxy_ajp.so

apache配置虚拟主机指定 proxy pass 
<VirtualHost *:80>
       DocumentRoot "/var/lib/tomcat/webapps/ROOT"
       ServerName java.evcharge.cc
       ProxyRequests On
       proxypass / ajp://localhost:8009/
       <Directory "/var/lib/tomcat/webapps/ROOT">
           Allow from all
           Require all granted
      </Directory>
</VirtualHost>


/usr/share/tomcat下 /conf/server.xml
启用ajp (不要注释此行)
 <Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />




强制反向代理可以:

ProxyPass / ajp://localhost:8009/  

ProxyPassReverse / ajp://localhost:8009/

参考:

http://www.open-open.com/lib/view/open1350702594664.html

http://blog.csdn.net/daleiwang/article/details/29611779

2.(现在做负载均衡自apache后起已经可以用自带集成的)

http://www.cnblogs.com/atyou/archive/2013/05/24/3097078.html

http://www.cnblogs.com/itech/archive/2009/08/18/1548723.html

centos nodejs 环境

1.确认是否有nodejs编译及依赖相关软件
    查看 rpm -qa | grep gcc ...
    没有则安装:  yum -y install gcc gcc-c++ openssl-devel

2.下载并安装文件,加入系统变量

2.1 下载安装加入系统变量 参考:http://zhaohe162.blog.163.com/blog/static/38216797201402234212981/

2.2 通过包管理器安装

1. 安装脚本
curl --silent --location https://rpm.nodesource.com/setup_4.x | bash -

2.安装文件
yum install -y nodejs
yum install -y npm //似乎是可选的 已集成npm

node ports相关文件
/usr/ports/www/node

原文地址:https://www.cnblogs.com/isdom/p/webclips051.html