新规实施:申请手机号码将全面实行人脸比对
06-18
原文地址:install yum-utils device-mapper-persistent-data lvm2 -y 设置镜像源代码语言:javascript copy yum-config-manager --add-repo install docker -ce docker -ce-cli containerd.io -y 启动docker 代码语言:javascript copy systemctl start docker# 设置启动 systemctl enable docker 设置docker镜像 源代码语言:javascript copy vi /etc/docker/daemon.json 代码语言: javascript copy { "registry-mirrors": [ " " ],} 后续拉取镜像直接从网站拉取速度更快并重启 docker 代码语言:javascript copy systemctl restart docker install mysql 镜像测试 代码语言:javascript copy docker pull daocloud.io /library /mysql:8.0.20 运行mysql镜像代码语言: javascript copy docker run -d -p :--name mysql -e MYSQL_ROOT_PASSWORD=56 (设置登录密码) be0dbf01a0f3 (镜像ID) 进入mysql容器。 mysql镜像构建成功。
下面我们使用docker-compose来管理docker容器。不用一一安装MySQL、redis、nginx,而是安装docker-compose代码语言: javascript copy # 使用国内源安装curl -L -s`-`uname -m` > /usr /local/bin/docker- compose 设置 docker-compose 执行权限 代码语言:javascript copy chmod +x /usr/local/bin/docker-compose 创建软链 代码语言:javascript copy sudo ln -s /usr/local/bin /docker-compose /usr/宾/做cker-compose 测试是否安装成功: 代码语言:javascript copy $ docker-compose --versiondocker-compose version 1.22.0, build f0fe 编写 docker-compose 代码语言:javascript copy version: "3.0" services: # Docker 容器启动的Redis默认没有redis.conf配置文件,所以在用docker启动redis之前,需要到官网下载redis.conf配置文件 redis: # 服务名称 container_name: redis # 容器名称 image: daocloud.io/library/redis: 6.0.3-alpine3.11 # 使用官方镜像 # 配置redis.conf启动命令: redis-server /usr/local/etc/redis/redis.conf --requirepass 56 --appendonly yes # 设置redis登录密码 56, --appendonly yes: 该命令用于启用redis数据持久化 # 无需配置文件启动 # 命令: redis-server --requirepass 56 --appendonly yes # 设置redis登录密码56 ports: - :# 本地端口: 容器端口 restart: on-failure # 自动重启volumes: - ./deploy/redis/db:/data # 挂载持久数据到主机 - ./deploy/redis/conf/redis.conf:/usr /local /etc/redis/redis.conf # 挂载redis配置文件到主机 - ./deploy/redis/logs:/logs # 用于存储日志的环境:- TZ=Asia/Shanghai # 解决容器时区问题?????????networks:?????????? - my-server??? mysql:??????? container_name: mysql???? image: daocloud.io/library/mysql:8.0.20 #?????????????? ports: ports: - :# Native port:container端口重启: on-failure 环境: - MYSQL_ROOT_PASSWORD=56 # root 用户密码volumes: - ./deploy/mysql/db:/var/lib/mysql # 用于存放数据库的表文件 - ./deploy/mysql/conf/ my.cnf: /etc/my.cnf#保留自定义的配置文件#我们自动创建了数据库和表#MySQL官方镜像在我们启动MySQL容器时提供了容器启动时的container-intrypoint-initdb.d。
- ./deploy/mysql/init:/docker-entrypoint-initdb.d/下脚本的作用 # 存放初始化脚本 -networks: - my-server server: # Egg service container_name: server Build: # 构建镜像基于 Dockerfile 上下文:. Dockerfile: Dockerfile Ports:-: Restart: On-Failure#设置自动重启。这一步一定要设置,主要是mysql没有启动就启动了NETWORKS: -My-Server。
depends_on: # 节点服务依赖mysql和redis - redis - mysql#声明网桥my-server# 重要:将所有服务挂载在同一个网桥上,可以通过容器名互相通信 # 例如egg连接mysql和redis,可以通过容器名networks: my-server:nestjs/ Dockerfile 代码语言:javascript Copy FROM daocloud.io/library/node:14.7.0# 设置时区 ENV TZ=亚洲/上海 \ DEBIAN_FRONTEND=noninteractiveRUN ln -fs /usr/share/zoneinfo/${TZ} /etc/localtime && echo ${TZ} > /etc/timezone && dpkg-reconfigure --frontend noninteractive tzdata && rm -rf /var/lib/apt/lists/*# 创建工作目录 RUN mkdir -p /app# 指定工作目录 WORKDIR / app# 将当前代码复制到 /app 工作目录 COPY 。 ./# npm源,选择国内镜像源,提高下载速度 # RUN npm config setregistry npm 安装依赖 RUN npm install # 打包 RUN npm run build # 启动服务 # "start:prod": "cross -env NODE_ENV=production node ./dist/src/main.js",CMD npm run start:prodEXPOSE 修改代码打开云服务器端口,打开端口,启动项目 docker-compose -h 查看命令 docker-compose up 启动服务和控制 平台可见日志 docker-compose up -d 后台启动服务 docker-compose build --no-cache 重新构建镜像,不使用缓存(最后启动 docker-compose up -d) 停止服务docker-compose down 下载镜像进程 docker-compose pull 重启服务 docker-compose restart 后台启动服务docker-compose up -d test 2.微信云托管部署。
云托管管道部署更加便捷。 redis服务就在我们上面部署的自建服务器上。
使用docker构建的redis服务作为演示mysql服务。这是我们上面部署的自建服务器。
使用docker搭建的mysql服务作为演示。修改代码,然后将代码上传到github。
通过云托管管道构建新服务。点击发布后,云主机将执行Dockerfile构建管道。
您可以在日志中查看构建进度。微信云托管部署成功后,您可以在实例列表中,点击进入容器查看代码。
这里的内容不能修改。容器启动后,会覆盖调试界面来测试redis。
3、腾讯云无服务器部署需要注意的是,云功能的代码包不能超过M模板部署——部署Nest。登录Serverless应用控制台,点击新建应用,选择Web应用>Nest.js框架,如下图: 点击“下一步”,完成基本配置,选择上传方式,选择示例代码直接部署,点击 Finish 即可开始应用部署。
部署完成后,您可以在应用详情页查看示例应用的基本信息,通过API网关生成的访问路径URL进行访问,查看您部署的Nest.js项目。定制部署。
Nest 初始化您的 Nest.js 项目代码。语言:javascript 复制 npm i -g @nestjs/clist new Nest-app 根目录下,执行以下命令,直接在本地启动服务。
代码语言: javascript copy cd Nest-app && npm run start 打开浏览器访问Nest.js示例项目。部署到云端接下来,执行以下步骤,对初始化的项目进行简单修改,以便可以通过Web Function快速部署。
这里的工程修改通常分为以下两步: 添加scf_bootstrap启动文件。修改监听地址和端口为0.0.0.0:。
修改启动文件main.ts,监听端口改为: 在项目根目录下新建scf_bootstrap启动文件,文件中添加以下内容(用于启动服务): 还可以完成模块配置在控制台中。代码语言: javascript copy# scf_bootstrap#!/bin/bashSERVERLESS=1 /var/lang/node12/bin/node ./dist/main.js 新建完成后需要执行以下命令修改文件可执行权限。
默认要求是 或 允许正常启动。示例如下: 代码语言:javascript 复制 chmod scf_bootstrap 本地配置完成后,执行启动文件,确保您的服务能够在本地正常启动。
接下来登录Serverless应用控制台,选择Web应用 > Nest.js框架,可以选择上传方式。本地上传或代码库pull 注意:启动文件以项目中的文件为准。
如果您的项目已包含 scf_bootstrap 文件,则内容不会被覆盖。单个函数的代码大小上限(以 MB 为单位)。
在实际操作中,虽然云函数提供了关于绕过配额问题的mb:如果超出的不多,那么使用 npm install --product 就可以解决问题。
版权声明:本文内容由互联网用户自发贡献,本站不拥有所有权,不承担相关法律责任。如果发现本站有涉嫌抄袭的内容,欢迎发送邮件 举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。
标签:
相关文章
06-18
06-17
06-17
06-18
最新文章
【玩转GPU】ControlNet初学者生存指南
【实战】获取小程序中用户的城市信息(附源码)
包雪雪简单介绍Vue.js:开学
Go进阶:使用Gin框架简单实现服务端渲染
线程池介绍及实际案例分享
JMeter 注释 18 - JMeter 常用配置组件介绍
基于Sentry的大数据权限解决方案
【云+社区年度征文集】GPE监控介绍及使用