OpenERP 部署环境使用说明

  OpenERP 上线文档 
                               Jack.Wang(Email:[email protected]
                               (2011-12-26) 
1. 系统基本配置: 
   1.1 操作系统: CentOS 5.6 
   1.2 磁盘划分: 
                /          -----------> 100G 
                /usr/local -----------> 200G 
                /home      -----------> 50G 
                /opt       -----------> 100G 
                swap       -----------> 10G 
   1.3 数据库:  postgresql-9.1.2(OpenERP6.0需要postgresql-8.2版本或者以上) 
   1.4 Python:  Python 2.6(OpenERP6.0需要Python2.5版本或者以上) 

2. 创建用户openerp(用于启动OpenERP的用户) 

3. 安装,配置数据库(postgresql): 
   ------------------------------------------------------------------------------ 
   3.1 安装: 
       # yum install postgresql postgresql-server 
       # yum install postgresql-devel (这是需要的,不然安装psycopg2是安装不了的) 
   3.2 配置: 
       3.2.1 设置服务开机自动启动: 
              # chkconfig postgresql on 
       3.2.2 启动服务: 
              # /etc/init.d/postgresql start 
   3.3 添加openerp用户: 
       3.3.1 # su - postgres 
       3.3.2 -bash-3.2$ createuser --no-superuser --createdb --no-createrole \ 
                                   --login --pwprompt --encrypted 
   ------------------------------------------------------------------------------ 
   由于CentOS 5.6默认的postgresql为8.1.23版本,是不符合要求的,所以需要自己手动编译 
   ------------------------------------------------------------------------------ 
   下载postgresql-9.1.2 
   系统需求确认: 
        make 3.80版本或者以上(满足make 3.81) 
        C compiler 
        tar gzip bzip2 
        readline readline-devel 
        zlib zlib-devel 
        full Perl installation, including the "libperl" library and the header files 
   安装: 
        解压缩postgresql-9.1.2.tar.bz2($POSTPATH) 
        # useradd postgres 
        # cd $POSTPATH 
        # ./configure 
        # make 
        # make install 
        # chown -R postgres:postgres /usr/local/pgsql 
        # su - postgres 
        $ /usr/local/pgsql/bin/initdb -D /usr/local/pgsql/data   # 初始化数据库 
        $ vim /usr/local/pgsql/data/postgresql.conf(根据需要) 
          去掉 listen_addresses 前面的注释并设置参数为 * 
          去掉 port 前面的注释        
        $ vim /usr/local/pgsql/data/pg_hba.conf(根据需要) 
        $ /usr/local/pgsql/bin/postgres -D /usr/local/pgsql/data 
          或者 
          (/usr/local/pgsql/bin/pg_ctl -D /usr/local/pgsql/data -l logfile start) # 启动服务器 
        $ /usr/local/pgsql/bin/createuser --no-superuser --createdb --no-createrole --login --pwprompt --encrypted (添加用户) 
        # ln -s /usr/local/pgsql/bin/psql /usr/bin/psql(创建软链接) 
        $ psql (登录) 
        ------------------------------------------------------------------------------------------------ 
        设置自动启动脚本 
        # cp /home/openerp/postgresql-9.1.2/contrib/start-scripts/linux /etc/init.d/postgres 
        # chomd +x /etc/init.d/postgres 
        # service postgres start (启动) 
        # chkconfig postgres on(开机自动启动数据库) 

4. 安装Python 2.6 
   ------------------------------------------------------------------------------------- 
   CentOS 5.6默认的Python版本为2.4的,所以需要自己手动安装Python 
   ------------------------------------------------------------------------------------- 
   4.1 下载源码:Python-2.6.tar.bz2 
   4.2 安装需要的库 
       # yum install sqlite-devel openssl-devel bzip2-devel gdbm-devel readline-devel \ 
                     ncurses-devel libxml2-devel libxslt-devel 
   4.3 解压缩,安装 
       $ tar jxvf Python-2.6.tar.bz2 
       $ cd Python-2.6 
       $ ./configure --prefix=/opt/apps/python2.6 
       $ make 
       $ make install 
       $ sudo ln -s /opt/apps/python2.6/bin/python /usr/bin/python2.6   #创建链接 
   4.4 安装easy_install 
       4.4.1 下载ez_setup.py 
       4.4.2 安装: 
             $ python2.6 ez_setup.py 
             $ sudo ln -s /opt/apps/python2.6/bin/easy_install /usr/bin/easy_install2.6 

5. 将/opt目录改为openerp拥有(openerp用户使用) 
   # chown openerp:openerp /opt/ 
   # su - openerp 
   $ mkdir /opt/apps  (用于存放OpenERP应用) 

6. 安装OpenERP需要的Python库 
   $ easy_install2.6 lxml 
   $ easy_install2.6 psycopg2 
   $ easy_install2.6 pyaml 
   $ easy_install2.6 reportlab 
   $ easy_install2.6 mako 
   $ easy_install2.6 pil 
   -------------------------------------------------------------------------------------- 
   $ easy_install2.6 cherrypy 
   $ easy_install2.6 formencode 
   $ easy_install2.6 simplejson 
   $ easy_install2.6 babel 
   $ easy_install2.6 pytz 
   -------------------------------------------------------------------------------------- 
   $ easy_install2.6 python-dateutil 

7. 启动OpenERP: 
   $ python2.6 /opt/apps/OpenERP/openerp-server/bin/openerp-server.py --db_user=openerp \ 
                                                               --db_password=openerp 
   $ python2.6 /opt/apps/OpenERP/openerp-web/openerp-web.py 
   --------------------------------------------------------------------------------------- 
   安装OpenERP(Server端): 
        $ cd /opt/apps/OpenERP/openerp-server/ 
        $ sudo python2.6 setup.py install 
        # ln -s /opt/apps/python2.6/bin/openerp-server /usr/bin/openerp-server 
        $ openerp-server (启动) 
   (Web端): 
        $ cd /opt/apps/OpenERP/openerp-web/ 
        $ sudo python setup.py install 
        # ln -s /opt/apps/python2.6/bin/openerp-web /usr/bin/openerp-web 
        $ openerp-web 
   具体用法: 
        $ openerp-server & 
        $ openerp-web & 
        上述命令如果是用ssh启动的话,会出现问题(ssh断开连接的时候,相应的开启的服务也会关闭),解决方案: 
        #nohup program &(可以保证关闭ssh后,ssh开启的服务依旧运行),即: 
        $ nohup openerp-server & 
        $ nohup openerp-web & 
        
8. 防火墙设置(开通8080访问的端口) 
   8.1 安装iptables 
       # yum install iptables 
   8.2 初始化iptables 
       # iptables -F 
   8.3 定制过滤规则 
       # vim /etc/sysconfig/iptables 
       ************************************************************ 
       *filter 
       :INPUT ACCEPT [0:0]        # 定义了内建的INPUT链 
       :FORWARD ACCEPT [0:0]      # 定义了内建的FORWARD链 
       :OUTPUT ACCEPT [0:0]       # 定义了内建的ACCEPT链 
       :RH-Firewall-1-INPUT - [0:0]  # 创建一个被称为RH-Firewall-1-INPUT的新链 
       -A INPUT -j RH-Firewall-1-INPUT   # 这条规则将添加到INPUT链上,所有发往INPUT链上的数据包将跳转到RH-Firewall-1链上 
       -A FORWARD -j RH-Firewall-1-INPUT 
       -A RH-Firewall-1-INPUT -i lo -j ACCEPT   # 这条规则将被添加到RH-Firewall-1-input链,他可以匹配所有的数据包,其中 
                                                # 流入接口(-i)是一个环路接口(lo), 匹配这条规则的数据包将全部通过(ACCEPT), 
                                                # 不会再使用别的规则来和它们进行比较 
       -A RH-Firewall-1-INPUT -p icmp --icmp-type any -j DROP  # 拒绝所有的icmp包-p后是协议如:icmp, tcp, udp。端口是 
                                                               # 在-p后面--sport源端口,--dport目的端口。-j指定数据包 
                                                               # 发送的 
       # 接受下面的防火墙设置 
       # -m state --state ESTABLISHED,RELATED这个条件表示所有处于 ESTABLISHED或者 RELATED状态的包,策略都是接受的。 
       # -m state --state NEW 这个条件是当connection的状态为初始连接(NEW)时候的策略 
       -A RH-Firewall-1-INPUT -m state --state ESTABLISHED,RELATED -j ACCEPT 
       -A RH-Firewall-1-INPUT -m state --state NEW -m tcp -p tcp --dport 22 -j ACCEPT 
       -A RH-Firewall-1-INPUT -m state --state NEW -m tcp -p tcp --dport 8080 -j ACCEPT 
       # 拒绝所有的 
       -A RH-Firewall-1-INPUT -j REJECT --reject-with icmp-host-prohibited 
       COMMIT 
   8.4 让规则生效 
       # /etc/init.d/iptables restart 
   8.5 测试通过 
       # ping 172.17.16.56 (ping不通) 

----------------------------------------------------------------------------------------------- 
遇到的问题: 
1. ImportError: No module named _thread 
   解决方案: 
        是dateutil版本的问题,降低版本为1.5 
        $ easy_install2.6 python-dateutil==1.5 
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章