apache2 django2 python3環境安裝

推廣自己的一個交流羣 需要labview學習交流的QQ羣:479946195   

需要labview代做的QQ號:1841456259

 

環境要求:Ubuntu14.04及以上,python3.4及以上

 

查看系統版本:cat /etc/issue

切換python版本

python2可能導致ImportError: No module named Django錯誤

查看python版本:python --version

一般Ubuntu系統自帶python,在/usr/bin可查看已安裝的版本

若爲python2,在系統級別更改版本:

羅列出所有可用的 python 替代版本信息:update-alternatives --list python

更新替代列表:

update-alternatives --install /usr/bin/python python /usr/bin/python2.7 1
update-alternatives --install /usr/bin/python python /usr/bin/python3.4 2

--install選項使用了多個參數用於創建符號鏈接。最後一個參數指定了此選項的優先級,如果我們沒有手動來設置替代選項,那麼具有最高優先級的選項就會被選中。

此時查看所有的替代版本:

切換python版本:

sudo update-alternatives --config python

會列出可切換的列表,填入數字:

移除替代版本示例:update-alternatives --remove python /usr/bin/python2.7

安裝python相關組件

安裝pip:sudo apt-get install python3-pip

安裝mysqlclient:sudo pip install mysqlclient

安裝django:sudo pip install django

如果出現mysql_config not found錯誤,安裝libmysqlclient-dev:sudo apt-get install libmysqlclient-dev

如果出現Python.h:No such file or directory,安裝python-dev:sudo apt-get install python-dev

 

 

安裝mysql

方法一:

docker pull mysql

sudo docker run --name mysql -p 3306:3306 -e MYSQL \_ROOT\_PASSWORD=123456 -d mysql        運行時須指定root密碼

運行時可能出現mysql.socket不存在的問題

方法二:

sudo apt-get install mysql-server       安裝時會要求輸入root密碼

注意檢查mysql是否有時區表,沒有的話可能出現UTC日誌轉換CONVERT_TZ出錯的情況

執行:

select * from mysql.time_zone;

select * from mysql.time_zone_name;

若爲空,執行

mysql_tzinfo_to_sql /usr/share/zoneinfo

注:mysql命令行登錄

mysql -u root -p mysql

輸入root密碼

 

安裝apache2

sudo apt-get install apache2

sudo apt-get install libapache2-mod-wsgi-py3

查看apache版本:apachectl -v

配置

 

我們希望在瀏覽器通過xxx.xxx.xxx訪問網站

新建一個apache2的網站配置文件:sudo vi /etc/apache2/sites-available/sitename.conf

[plain] view plain copy

  1. <VirtualHost *:8800>  
  2.     ServerName xxx.xxx.xxx  
  3.     DocumentRoot /var/www/a/b                          這裏是wsgi.py所在目錄  
  4.     <Directory /var/www/a/b>  
  5.         Order allow,deny  
  6.         Allow from all  
  7.     </Directory>  
  8.     <Directory /var/www/a/static>  
  9.        Require all granted  
  10.     </Directory>  
  11.     Alias /static /var/www/a/static  
  12.     WSGIScriptAlias / /var/www/a/b/wsgi.py  
  13.   
  14.     ErrorLog ${APACHE_LOG_DIR}/error_8800.log  
  15.     CustomLog ${APACHE_LOG_DIR}/access_8800.log combined  
  16. </VirtualHost>  

/etc/apache2/ports.conf下也將80端口改爲8800

這裏使用的端口是8800,因爲我們這裏80端口被nginx佔用

在nginx的配置文件中修改

 

[plain] view plain copy

  1. location / {  
  2.     proxy_pass http://127.0.0.1:8800;  
  3. }  

重啓nginx:

sudo nginx -s reload

一般將根目錄及以下目錄權限設置爲755,文件權限設置爲644

sudo chmod -R 644 a

sudo find a -type d | xargs chmod 755

如果有上傳需求,將上傳文件夾設置寫權限

激活網站:sudo a2ensite sitename 或 sudo a2ensite sitename.conf

 

更改網站程序需要重啓apache2,service apache2 restart若無效

ps -aux | grep apache2 將三個進程全部殺死

kill -s 9 <pid>

再啓動service apache2 start

調試

Django的日誌在/your_project_name/settings.py文件中配置。具體配置如下:


LOGGING = {
    'version': 1,
    'disable_existing_loggers': False,
    'formatters': {
        'standard': {
            'format': '%(asctime)s %(levelname)-8s %(message)s'
        },
        'detail': {
            'format': '%(asctime)s %(levelname)-8s %(pathname)s[line:%(lineno)d] %(message)s'
        },
    },
    'handlers': {
        'console': {
            'level': 'INFO',
            'class': 'logging.StreamHandler',
            'formatter': 'standard',
        },
        'file': {
            'level': 'INFO',
            'class': 'logging.handlers.RotatingFileHandler',
            'filename': '/var/log/django.log',
            'maxBytes': 1024 * 1024 * 5,  # 5 MB
            'backupCount': 100,
            'formatter': 'detail',
        },
        'app1_file': {
            'level': 'INFO',
            'class': 'logging.handlers.RotatingFileHandler',
            'filename': '/var/log/app1.log',
            'maxBytes': 1024 * 1024 * 5,  # 5 MB
            'backupCount': 100,
            'formatter': 'detail',
        },
        'app2_file': {
            'level': 'INFO',
            'class': 'logging.handlers.RotatingFileHandler',
            'filename': '/var/log/app2.log',
            'maxBytes': 1024 * 1024 * 5,  # 5 MB
            'backupCount': 100,
            'formatter': 'detail',
        },
    },
    'loggers': {
        'django': {
            'handlers': ['console', 'file'],
            'level': 'INFO',
            'propagate': True,
        },
        # 自定義模塊日誌
        'users': {
            'handlers': ['console', 'file'],
            'level': 'DEBUG',
            'propagate': True,
        },
        'common': {
            'handlers': ['console', 'file'],
            'level': 'DEBUG',
            'propagate': True,
        },
        'myapp': {
            'handlers': ['console', 'file'],
            'level': 'DEBUG',
            'propagate': True,
        },
        'app1': {
            'handlers': ['console', 'app1_file'],
            'level': 'INFO',
            'propagate': True,
        },
        'pushdata': {
            'handlers': ['console', 'app2_file'],
            'level': 'INFO',
            'propagate': True,
        },

    },
}

此配置分成三個部分:

  • formatters: 指定輸出的格式,被handler使用。
  • handlers: 指定輸出到控制檯還是文件中,以及輸出的方式。被logger引用。
  • loggers: 指定django中的每個模塊使用哪個handlers。以及日誌輸出的級別。

注意:日誌的輸出級別是由loggers中的每個模塊中level選項定義。如果沒有配置,那麼默認爲warning級別。

然後在每個模塊的views.py中,通過下面代碼使用:


import logging
logger = logging.getLogger(__name__)

具體的輸出部分代碼爲:

logger.debug("hello, world")
logger.info("hello, world")
logger.error("hello, world")

日誌在/var/log/apache2/

如果採用print來打印調試信息

python manage.py runserver --noreload

這樣print出來的信息就可以在終端看到了,但是這樣作,每次python代碼有修改,就要重啓服務器。

參考鏈接:

http://www.linuxidc.com/Linux/2007-07/6178.htm

http://blog.csdn.net/u011534057/article/details/51615193

https://segmentfault.com/q/1010000003713912

https://stackoverflow.com/questions/18363022/importerror-no-module-named-pip

http://www.cnblogs.com/xiazh/archive/2012/12/12/2814289.html

http://blog.csdn.net/hello_orange/article/details/6184420

http://code.ziqiangxuetang.com/django/django-deploy.html

http://www.cnblogs.com/OnlyDreams/p/7171612.html

http://www.cnblogs.com/zhangqunshi/p/6641173.html

https://zhidao.baidu.com/question/496750276253579564.html

 

版權聲明:本文爲博主原創文章,未經博主允許不得轉載。 https://blog.csdn.net/y_f_raquelle/article/details/76736465

個人分類: Django

 

想對作者說點什麼? 我來說一句

apache2部署django的錯誤

apache的日誌如下報錯: /var/www/my_project/myproject/wsgi.py cannot be loaded as Python module ImportError:...

duomoke duomoke

2015-06-24 11:20:18

閱讀數:1192

Ubuntu16.04下Apache2.4部署Django1.8.7

一、搭建環境 1)        安裝Django1.8.7 sudo apt-get install python-django-y 2)        安裝Apache sudo ...

u013382233 u013382233

2016-12-02 20:33:05

閱讀數:2473

早知道痔瘡這麼簡單就能好,還做什麼手術啊.上海華膚醫院 · 頂新

在服務器上用Apache2通過mod_wsgi 佈置django網站

Os:ubuntu 14.04 LTC 服

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章