1.安装mysql

Sudo apt-get install mysql

配置mysql的数据存储路径,默认在 /var/lib/mysql

sudo cp -R /var/lib/mysql/* /home/applex/mysqldb

sudo chown -R  mysql:mysql home/applex/mysqldb

sudo gedit /etc/mysql/mysql.conf.d/mysqld.cnf
将 [mysqld] 组下的 datadir改为:

datadir = /home/applex/mysqldb
sudo vim /etc/apparmor.d/usr.sbin.mysqld

把  

/var/lib/mysql r  

/var/lib/mysql/** rwk  

修改成  

/home/applex/mysqldb r  

/home/applex/mysqldb/** rwk

重启mysql

sudo service apparmor restart

sudo service mysql restart

或

sudo  /etc/init.d/apparmor restart

sudo  /etc/init.d/mysql restart   

配置msyql编码为utf8

sudo gedit /etc/mysql/mysql.conf.d/mysqld.cnf

在[mysqld]下面添加:

character-set-server=utf8
sudo gedit /etc/mysql/conf.d/mysql.cnf

添加
default-character-set=utf8 sudo gedit /etc/mysql/debian.cnf

添加
default-character-set=utf8

2.配置anaconda3

 

从官网下载当前最新sh安装脚本,执行

bash Anaconda3-2018.12-Linux-x86_64.sh

按照提示安装

conda的安装路径中不要包含中文, 根据项目创建虚拟环境并选择python3.6,其他具体操作方法见conda教程

conda create -n myenv python=3.6

3.conda环境中部署项目

若源码部署方式,conda虚拟环境切换到源码目录,执行

pip install -e .

注意源码目录必须包含setup.py 和  MANIFEST.ini

若以模块文件部署方式, conda虚拟环境切换到wheel文件目录,执行

pip install xxx.whl

模块安装后需要指定一个项目启动目录并编写入口文件,如下例:

# [main.py]

form myproject import app

if ‘__main__’ == __name__:

app.run()

可以执行python main.py 启动flask内置服务器来测试打包的项目模块是否可以正常运行

4.安装uwsgi

切换到conda虚拟环境下,用pip安装uwsgi:

conda activate myenv

pip install uwsgi

安装uwsgi报UnicodeEncoding错误,请确认conda路径是否包含unicode字符(例如中文)

 

安装uwsgi报如下错,安装配置gcc4.7

/home/applex/conda/envs/myproject/compiler_compat/ld: error: lto-wrapper failed:

sudo apt-get install gcc-4.7

sudo rm /usr/bin/gcc

sudo ln -s /usr/bin/gcc-4.7 /usr/bin/gcc

执行uwsgi –help确认uwsgi是否正确安装

uwsgi –help 查看帮助信息,若报如下错,安装配置libpcre3-dev

uwsgi: error while loading shared libraries: libpcre.so.1: cannot open shared object file: No such file or directory

sudo apt-get install libpcre3 libpcre3-dev

find / -name libpcre.so.3

找到 /lib/x86_64-linux-gnu/libpcre.so.3

sudo ln -s /lib/x86_64-linux-gnu/libpcre.so.3 /usr/lib/libpcre.so.1

编写uwsgi配置脚本

# [my_uwsgi.ini]

# 指定python环境

pythonpath = /home/applex/conda/envs/myproject/bin

# 启动http地址还是socket地址(用于与代理通信)

http = 127.0.0.1:7878

# socket = 127.0.0.1:7878

# 指定进程数(同process项)

workers = 4

# 指定线程数

threads = 2

# 设置日志路径

daemonize = /home/applex/myproject/server.log

# 设置app启动目录

chdir = /home/applex/myproject

# 设置app启动文件(也可直接指定文件全路径,无依赖时省略chdir)

# 注意引用的py文件不能在调用时启动app实例

wsgi-file = ./main.py

# 指定application对象实例

callable= app

  

启动uwsgi服务器

uwsgi mypath/ my_uwsgi.ini

查看uwsgi是否运行

ps -aux | grep uwsgi

查看端口号占用

netstat -anp | grep 7878

结束uwsgi进程

pgrep uwsgi | xargs kill -s 9

在配置的daemonize参数指定的文件中查看错误日志

5. 安装redis

sudo apt-get install redis-server

6.安装nginx

sudo apt-get install nginx

 

删除/etc/nginx/sites-enabled目录下的default链接,复制/etc/nginx/sites-available/default到/etc/nginx/sites-enabled,并按需求命名为myproject.conf,拷贝uwsgi_params到项目路径以便后期客制

cp /etc/nginx/uwsgi_params /home/applex/myproject/

修改myproject.conf,增加:

server {

listen 80;

listen [::]:80;

server_name 127.0.0.1;

charset utf-8;

        # 转发url请求到uwsgi

        location / {

            include /home/applex/myproject/uwsgi_params;

            uwsgi_pass 127.0.0.1:8000;

            uwsgi_param UWSGI_CHDIR /home/applex/myproject;

            uwsgi_param UWSGI_SCRIPT main:app;

        }

        # 配置nginx处理静态文件

        location /static {

            alias /home/applex/conda/envs/myproject/lib/python3.6/site-packages/myproject/static;

        }

}

  

操作nginx服务

sudo service nginx start/stop/reload

Ubuntu16.04下搭建mysql + uwsgi + nginx环境启动flask 项目的更多相关文章

  1. Ubuntu16.04下搭建开发环境及编译tiny4412 Android系统【转】

    本文转载自:http://blog.csdn.net/songze_lee/article/details/72808631 版权声明:本文为博主原创文章,未经博主允许不得转载. 1.安装ssh服务器 ...

  2. ubuntu16.04下 搭建 lnmp 环境

    apt-get install nginx apt-get php7.-mysql apt-get install mysql 编辑nginx配置文件 vim /etc/nginx/sites-ena ...

  3. ubuntu16.04下安装配置深度学习环境(Ubuntu 16.04/16.10+ cuda7.5/8+cudnn4/5+caffe)

    主要参照以下两篇博文:http://blog.csdn.net/g0m3e/article/details/51420565   http://blog.csdn.net/xuzhongxiong/a ...

  4. 在 Ubuntu16.04 中搭建 Spark 单机开发环境 (JDK + Scala + Spark)

    1.准备 本文主要讲述如何在Ubuntu 16.04 中搭建 Spark 2.11 单机开发环境,主要分为 3 部分:JDK 安装,Scala 安装和 Spark 安装. JDK 1.8:jdk-8u ...

  5. Ubuntu 16.04下搭建kubernetes集群环境

    简介 目前Kubernetes为Ubuntu提供的kube-up脚本,不支持15.10以及16.04这两个使用systemd作为init系统的版本. 这里详细介绍一下如何以非Docker方式在Ubun ...

  6. Ubuntu16.04下修改MySQL数据的默认存储位置

    由于在Linux下MySQL默认是存储在/var/lib/mysql目录下,mysql的数据会非常大,由于/var所划分的空间不够大,所以我们需要将mysql数据存放路径修改一下,放到大分区里面,以便 ...

  7. Caffe学习系列(一)Ubuntu16.04下搭建编译Caffe环境,并运行MNIST示例(仅CPU)

    前言: 正文: 1.安装必要依赖包: sudo apt-get install libprotobuf-dev libleveldb-dev libsnappy-dev libopencv-dev l ...

  8. Ubuntu16.04下搭建Go语言环境

    1. 安装GO sudo apt-get install golang-go 2. 设置Go环境变量 打开终端,输入命令: export GOROOT=$HOME/goexport PATH=$GOR ...

  9. Ubuntu16.04下搭建LAMP环境

    前期准备sudo apt-get update             # 获取最新资源包sudo apt-get upgrade           # 本机软件全部更新sudo apt-get d ...

随机推荐

  1. Java8新特性之四:接口默认方法和静态方法

    在JDK1.8以前,接口(interface)没有提供任何具体的实现,在<JAVA编程思想>中是这样描述的:"interface这个关键字产生了一个完全抽象的类,它根本就没有提供 ...

  2. SpringCloud学习系列之二 ----- 服务消费者(Feign)和负载均衡(Ribbon)使用详解

    前言 本篇主要介绍的是SpringCloud中的服务消费者(Feign)和负载均衡(Ribbon)功能的实现以及使用Feign结合Ribbon实现负载均衡. SpringCloud Feign Fei ...

  3. Android startActivity原理分析(基于Android 8.1 AOSP)

    应用进程内 如何使用Intent做Activity的跳转 Intnet intent = new Intent(MainActivity.this,TestActivity.class); start ...

  4. sql语句 汉字转拼音首字母

    (1)------------------------------------------------------------------------------------------------- ...

  5. The operation could not be performed because OLE DB provider "SQLNCLI11" for linked server "SDSSDFCC" was unable to begin a distributed transaction.

    Question: SQL SERVER 通过Linkserver连接A和B 2台,A对B执行单条的增删改查没有异常(没有配置DTC) 但是开启事务后就会出现报错 Solution: 在A和B上配置D ...

  6. Followme Devops实践之路

    引言 天下武功,唯快不破 想要提高开发团队效率,势必要有一套完整而成熟的开发流程方案,除了sprint迭代开发模式之外,还有近几年流行的devops流程,都是可以大幅度提高开发效率的工具. 我们团队也 ...

  7. webpack学习笔记一:安装webpack、webpack-dev-server、内存加载js和html文件、loader处理非js文件

    一 .webpack学习环境准备: 1:window系统 2:安装node.js  官方网址 下载好后下一步下一步安装即可 安装步骤略过....... 3:nrm的安装 打开cmd命令控制台 输入:n ...

  8. dubbo 序列化机制之 hessian2序列化实现原理分析

    对于远程通信,往往都会涉及到数据持久化传输问题.往大了说,就是,从A发出的信息,怎样能被B接收到相同信息内容!小点说就是,编码与解码问题! 而在dubbo或者说是java的远程通信中,编解码则往往伴随 ...

  9. 关于Bulk加载模式

    Bulk加载模式是Informatica提供的一种高性能数据加载模式,它利用数据库底层机制,依靠调用数据库本身提供的Utility来进行数据的加载 该方式将绕过数据库的log记录,以此提高数据库加载性 ...

  10. C语言中的神兽strdup

    C语言的确博大精深,在C语言的世界中遨游了那么多年,发现自己仍是菜鸟一枚,很多利器没有能够驾驭,今天介绍一个神兽,威力无比,但是却很少人能用得好. 函数原型: #include <string. ...