Docker 部署Streamlit项目 | Streamlit如何部署到云服务器

简介: Docker 部署Streamlit项目 | Streamlit如何部署到云服务器


前言: 关于streamlit

关于streamlit:


Docker 部署Streamlit项目 | Streamlit如何部署到云服务器

1、安装docker

  • 注:安装之前,先关闭SELINUX服务
    SELINUX是CentOS系统捆绑的安全服务程序,因为安全策略太过于严格,所以建议关闭这项服务
    修改/etc/selinux/config文件,设置SELINUX=disabled
vi /etc/selinux/config
  • 将 SELINUX=enforcing 改为 SELINUX=disabled

安装Docker服务,-y代表默认安装

yum install docker -y

方便做法:直接宝塔面板软件商店安装

注:docker常用命令

service docker start # 启动docker服务
service docker stop # 停止docker服务
service docker restart # 重启docker服务

2、拉取python镜像

2.1、什么是DockerHub?

  • DockerHub是Docker公共镜像仓库,为用户提供了大量的镜像文件
    https://hub.docker.com/
    由于国内网络访问DockerHub很慢,无法下载镜像文件,我们可以使用Docker加速器

2.2、配置docker加速器

DaoCloud加速器采用自主研发的智能路由及缓存技术并引入了先进的协议层优化,极大提升拉取镜像的速度和体验

(配置配置docker加速器的时候可以先关闭docker服务然后再重启)

curl -sSL https://get.daocloud.io/daotools/set_mirror.sh | sh -s http://f1361db2.m.daocloud.io

注意:修改/etc/docker/daemon.json文件,去掉结尾的逗号

2.3、拉取python镜像

docker pull python:3.6

3.6指的是是Python的版本

3. 创建python容器

3.1、首先创建网段

默认情况下,Docker环境会给容器分配动态的IP地址,这就导致下次启动容器的时候,IP地址就改变了

我们可以单独创建一个Docker内部的网段(172.20.0.X)

docker network create --subnet=172.20.0.0/16 pynet
  • /16表示创建出来的网段可以创建65534个IP地址;
  • 如果创建失败可能是因为网段已经被占用,可以试试其他的网段;

3.2、在创建的网段范围内创建python容器

docker run -it -d --name=StreamlitHelloWorld -p 5002:8501 -v /www/wwwroot/experiment/StreamlitHelloWorld:/root/StreamlitHelloWorld --net pynet --ip 172.20.0.3 python:3.6 bash

注:

  • **docker run :**创建一个新的容器并运行一个命令
  • -i: 以交互模式运行容器,通常与 -t 同时使用;
  • -t: 为容器重新分配一个伪输入终端,通常与 -i 同时使用;
  • -d: 后台运行容器,并返回容器ID;
  • –name=“nginx-lb”: 为容器指定一个名称;
  • -p: 指定端口映射,格式为:主机(宿主)端口:容器端口
  • –volume , -v: 绑定一个卷(目录映射)(/www/wwwroot/experiment/exp2是我的项目文件所在的真实位置;/root/project是docker内文件位置)
  • –net: 指定容器的网络连接类型,支持 bridge/host/none/container: 四种类型;
  • -ip:指定IP地址(虚拟);在pynet网段所在的范围内创建;(172.20.0.1是网关地址,不能使用,172.20.0.2以及之后的可以使用)
  • python:3.6 指定使用的镜像

4、启动服务streamlit服务

进取容器内部之后,转到项目启动文件所在目录,输入

streamlit run helloworld.py

输入网址:http://101.32.183.14:5002/ 访问(注意端口映射到了5002)

  • 注意:此时直接按下“Ctrl+c”退出运行的话,就是结束了python程序,然后在无法访问了;

稳妥的方法是:

加上nohup,使用命令:

nohup streamlit run helloworld.py

然后直接关上终端窗口即可;

5、docker常用命令

docker images # 列出本地镜像
docker ps -a # 查看所有的容器
docker start <容器 ID> # 启动容器
docker stop <容器 ID> # 停止容器
docker restart <容器 ID> # 停止的容器可以通过 docker restart 重启:
docker exec -it nlp bash # 进入"nlp"容器
docker network rm pynet # 删除pynet网段

6、可能的报错:

创建网段的时候:

ERROR response from daemon: Pool overlaps with other one on this address space

  • 在docker中创建networks的时候有时候会报ERROR: Pool overlaps with other one on this address space的错误,这是因为目标网段已经存在的原因,通常这发生在将要创建的networks手动指定了subnet网段地址的时候。| 这时有两个选择,一是查看已存在的网段是否有容器正在使用,如果没再用了可以删除该网段对应的网卡,二是修改目标的subnet网段地址。
  • 注意:默认情况下,docker默认创建的网段为172.17.0.X,因此创建的容器都是放在这个网段之中。
  • 如果报错,可能是之前创建的容器已经使用了这个网段,那就另外选择其他的网段
相关实践学习
2分钟自动化部署人生模拟器
本场景将带你借助云效流水线Flow实现人生模拟器小游戏的自动化部署
7天玩转云服务器
云服务器ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,可降低 IT 成本,提升运维效率。本课程手把手带你了解ECS、掌握基本操作、动手实操快照管理、镜像管理等。了解产品详情:&nbsp;https://www.aliyun.com/product/ecs
相关文章
|
13天前
|
弹性计算 监控 负载均衡
|
11天前
|
存储 Linux Docker
docker在欧拉服务器上编译安装应该注意什么?如何操作?
【10月更文挑战第31天】docker在欧拉服务器上编译安装应该注意什么?如何操作?
34 2
|
6天前
|
人工智能 API 数据安全/隐私保护
使用 Docker 一键免费部署 63.8k 的私人 ChatGPT 网页应用
NextChat 是一个可以在 GitHub 上一键免费部署的私人 ChatGPT 网页应用,支持 GPT3、GPT4 和 Gemini Pro 模型。该项目在 GitHub 上获得了 63.8k 的 star 数。部署简单,只需拉取 Docker 镜像并运行容器,设置 API Key 后即可使用。此外,NextChat 还提供了预设角色的面具功能,方便用户快速创建对话。
54 22
使用 Docker 一键免费部署 63.8k 的私人 ChatGPT 网页应用
|
7天前
|
弹性计算 开发工具 git
2分钟在阿里云ECS控制台部署个人应用(图文示例)
作为一名程序员,我在部署托管于Github/Gitee的代码到阿里云ECS服务器时,经常遇到繁琐的手动配置问题。近期,阿里云ECS控制台推出了一键构建部署功能,简化了这一过程,支持Gitee和GitHub仓库,自动处理git、docker等安装配置,无需手动登录服务器执行命令,大大提升了部署效率。本文将详细介绍该功能的使用方法和适用场景。
2分钟在阿里云ECS控制台部署个人应用(图文示例)
|
17天前
|
SQL 关系型数据库 数据库
国产数据实战之docker部署MyWebSQL数据库管理工具
【10月更文挑战第23天】国产数据实战之docker部署MyWebSQL数据库管理工具
56 4
国产数据实战之docker部署MyWebSQL数据库管理工具
|
7天前
|
运维 开发者 Docker
Docker Compose:简化容器化应用的部署与管理
Docker Compose:简化容器化应用的部署与管理
|
7天前
|
Docker 微服务 容器
使用Docker Compose实现微服务架构的快速部署
使用Docker Compose实现微服务架构的快速部署
17 1
|
14天前
|
PHP 数据库 数据安全/隐私保护
布谷直播源码部署服务器关于数据库配置的详细说明
布谷直播系统源码搭建部署时数据库配置明细!
|
19天前
|
消息中间件 Linux RocketMQ
在Red Hat Enterprise Linux 9上使用Docker快速安装并部署
通过以上步骤,你可以在Red Hat Enterprise Linux 9上使用Docker快速安装并部署RocketMQ。这种方法不仅简化了安装过程,还提供了一个灵活的环境来管理和扩展消息队列系统。RocketMQ作为一款高性能的分布式消息系统,通过Docker可以实现快速部署和高效管理。
46 2
|
7天前
|
前端开发 开发者 Docker
深入探索Docker Compose:简化多容器应用的部署
深入探索Docker Compose:简化多容器应用的部署
27 0