【Java】微服务项目的部署

news2024/12/29 14:21:49

微服务项目的部署

  • 准备
  • Centos安装 Docker
    • 镜像加速
      • 检查加速器是否生效
    • 下载docker-compose
      • 方法1 curl
      • 方法2 pip
      • 方法3 直接下载released
  • 用docker-compose部署中间件
  • 导入项目
    • 安装jdk + maven + git
    • 设置idea内存
      • 减小jar启动占用内存
      • 增加idea可使用内存

本文参考 https://gitee.com/gz-yami/mall4cloud,结合自己的思考和实际进行修改,侵联删

准备

  • 阿里云轻量应用服务器,操作系统版本CentOS 7
  • Xshell(用来连接云服务器)
  • IntelliJ IDEA 2022.1.3

Centos安装 Docker

从 2017 年 3 月开始 docker 在原来的基础上分为两个分支版本: Docker CE 和 Docker EE。

Docker CE 即社区免费版,Docker EE 即企业版,强调安全,但需付费使用。

本文介绍 Docker CE 的安装使用。

移除旧的版本:

$ sudo yum remove docker \
                  docker-client \
                  docker-client-latest \
                  docker-common \
                  docker-latest \
                  docker-latest-logrotate \
                  docker-logrotate \
                  docker-selinux \
                  docker-engine-selinux \
                  docker-engine

安装一些必要的系统工具:

sudo yum install -y yum-utils device-mapper-persistent-data lvm2

添加软件源信息:

sudo yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

更新 yum 缓存:

# centos 7
sudo yum makecache fast
# CentOS 8 没有fast这个命令
sudo yum makecache

安装 Docker-ce:

sudo yum -y install docker-ce

查看已安装docker版本

docker version

启动 Docker 后台服务

sudo systemctl start docker

开机启动

sudo systemctl enable docker

镜像加速

鉴于国内网络问题,后续拉取 Docker 镜像十分缓慢,我们可以需要配置加速器来解决。

可以使用阿里云的docker镜像地址:https://7qyk8phi.mirror.aliyuncs.com

新版的 Docker 使用 /etc/docker/daemon.json(Linux,没有请新建)。

请在该配置文件中加入:

(没有该文件的话,请先建一个)

{
  "registry-mirrors": ["https://7qyk8phi.mirror.aliyuncs.com"]
}

重启docker

sudo systemctl daemon-reload
sudo systemctl restart docker

检查加速器是否生效

配置加速器之后,如果拉取镜像仍然十分缓慢,请手动检查加速器配置是否生效,在命令行执行 docker info,如果从结果中看到了如下内容,说明配置成功。

Registry Mirrors:
 https://7qyk8phi.mirror.aliyuncs.com/

下载docker-compose

方法1 curl

#运行此命令以下载 Docker Compose 的当前稳定版本
sudo curl -L "https://github.com/docker/compose/releases/download/1.29.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
#对二进制文件应用可执行权限
sudo chmod +x /usr/local/bin/docker-compose
#测试安装
docker-compose --version
#若有docker-compose version 1.29.2, build 5becea4c,则安装成功

上面那个github的下载不了可以换一个

curl -L https://get.daocloud.io/docker/compose/releases/download/1.29.2/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose

方法2 pip

如果还是失败,可以再换pip安装

1、安装python-pip

yum -y install epel-release

yum -y install python-pip

2、安装docker-compose

pip install docker-compose

待安装完成后,执行查询版本的命令确认安装成功

docker-compose version

方法3 直接下载released

但是这些方式都不如直接去github下一个包https://github.com/docker/compose/releases/tag/1.29.2

  1. 上传docker-compose文件到Linux系统(xshell有时候不太好用,可以考虑vscode中的SFTP插件)
  2. 将文件移动到/msr/1oca1/bin目录中
mv docker-compose-Linux-x86_64 /usr/local/bin/docker-compose
  1. 赋予执行权限
chmod +x /usr/local/bin/docker-compose

用docker-compose部署中间件

1.在文件编辑器上,使用全局替换的方式,将文件夹下的所有 192.168.1.46替换为服务器的ip

2.将所有中间件文件及文件夹打包上传到服务器,效果如图所示

3.执行授权命令

chmod -R 777 ./rocketmq/broker/logs
chmod -R 777 ./rocketmq/broker/store
chmod -R 666 ./minio/data
chmod -R 777 ./elasticsearch/data

4.启动容器

ps: 容器一共要下载7G左右的数据,请耐心等待

docker-compose up -d --build

5.各个端访问路径及其密码

请自行192.168.1.46替换为服务器ip

  • mysql: 使用数据库连接工具进行连接, 端口3306 账号及密码 root/root
  • minio: http://192.168.1.46:9000 账号及密码 admin/admin123456
  • redis: 端口6379,没有密码
  • nacos: http://192.168.1.46:8848/nacos 账号及密码 nacos/nacos
    • 注意检查naocs是否启动成功;nacos地址是否正确;nacos的8848、9848端口是否开放
  • kibana: http://192.168.1.46:5601
    -rocketmq-dashboard:http://192.168.1.46:8180

6.访问minio管理页面,右下角有个加号,创建存储区域(create bucker) 名为mall4cloud
在这里插入图片描述

若要前端可以读取图片,需要设置权限

在这里插入图片描述

7.创建es索引

新建索引

根据自己本地ip地址打开控制台,如下界面

http://192.168.1.46:5601/app/dev_tools#/console

在这里插入图片描述

需创建order、product两个索引

复制下述命令到左框,点击执行后即可

命令的内容参考本目录下…/es/order.md …/es/product.md
在这里插入图片描述

导入项目

安装jdk + maven + git

使用git下载项目

使用idea,点击open,打开下载好的目录

使用ctrl + shift + r 全局替换掉 192.168.1.46 为中间件服务器ip

设置idea内存

在idea启动所有的项目,是很吃力的事情。所以要修改下idea的配置,让其能有足够的内存启动项目

减小jar启动占用内存

编辑虚拟机配置,将每个服务的内存改为512M,-Xms512m -Xms512m -Xss256k,如果机器实在内存不够,可以将512适当减少,但是减少到一定程度,如256m会造成java虚拟机频繁的垃圾回收,会更加卡,所以推荐512m。

在这里插入图片描述

增加idea可使用内存

编辑idea配置,增加内存,至少变为2G,根据需要,可以适当增大,以提高流畅度。

-Xms512m
-Xmx2048m
-XX:ReservedCodeCacheSize=512m
-XX:+UseConcMarkSweepGC
-XX:SoftRefLRUPolicyMSPerMB=100
editvm

idea配置
在这里插入图片描述
在这里插入图片描述

配置完毕,重启idea,此时可以启动所有项目。

  1. 启动项目
    在这里插入图片描述

框框中的是必须启动的项目,其他是按需启动,推荐全部都启动起来,需要一台16G内存以上的电脑

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/760893.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

音乐怎么转换成wav格式?分享这五个方法给大家!

在音频编辑和处理过程中,将音乐文件转换为WAV格式是一种常见需求。WAV格式以其无损音质和广泛的兼容性而受到许多人的喜爱。下面介绍了五种常用的方法,帮助您将音乐文件转换为WAV格式,其中方法一使用记灵在线工具。 方法一:记灵在…

非常规自增自减

非常规自增自减 目录 一. 概述二. 例题 一. 概述 在C语言的单目操作符中有(自增)和–(自减)这两个运算符。假设有变量i,我想让变量i加上1,那么我们会写成ii1这样的形式。…

自旋锁与开关中断临界区的区别

自旋锁和开关中断临界区都是用于保护共享资源的机制,但它们的实现方式和使用场景有所不同。 自旋锁主要是用于多核CPU上的并发编程中,它通过不断地检查锁的状态来等待锁的释放,从而避免了线程的阻塞。当一个线程需要访问共享资源时&#xff…

VTK 三维模型 体绘制 关于环境光、漫反射、镜面反射

光源: 1):环境光:环境光是一种低强度的光,由光线经过周围环境表面多次反射后形成的,利用环境光可以描述一块区域的亮度,通常在场 景中,环境光的颜色是一个常量. 2):太阳光:即定向光源,特点是从无穷远出发射光线,光线是平行的,光线强度不会随着距离衰减. 3):点光源:在有限空间…

maven安装和换源

1. 安装(17条消息) maven历史版本下载和安装_beiback的博客-CSDN博客 安装 maven历史版本仓库 下载 Index of /dist/maven/maven-3 (apache.org)https://archive.apache.org/dist/maven/maven-3/ 选择对应版本-binaries/-zip 解压即可使用 2.换源 (17条消息) 手把手教你更改…

【读书笔记】从实模式到保护模式

计算机语言 x86汇编语言:从实模式到保护模式(操作系统引导课) 原书作者李忠 用电表示数据 寄存器的作用:具有记忆功能的器件。锁存可以通过下面的开关控制,平时开关为空,按下开关之后,将输入锁…

PLEX如何搭建个人局域网的视频网站

Plex是一款功能非常强大的影音媒体管理系统,最大的优势是多平台支持和界面优美,几乎可以在所有的平台上安装plex服务器和客户端,让你可以随时随地享受存储在家中的电影、照片、音乐,并且可以实现观看记录无缝衔接,手机…

VScode——NPM脚本窗口找不到

一、问题描述(NPM终端在任务栏左侧找不到) VScode(Visual Studio Code)版本:1.79.2 二、解决办法 第一步:通过设置/用户设置/扩展/MPM更改NPM默认配置,如下图所示: 第二步&#xff…

[java安全]CommonsCollections6

文章目录 【java安全】CommonsCollections6**测试环境**前言分析TiedMapEntry注意点一注意点二POC调用栈 【java安全】CommonsCollections6 测试环境 3.1-3.2.1,jdk1.7,1.8 前言 之前我们分析了CommonsCollections1 LazyMap利用链,但是在java 8u71以…

2023 年中回顾:珍惜当下,锻炼身体

文章大纲 过去几十年的经验:人类的悲喜并不相同马太效应破圈:健康的身体写博客这件事:价值导向参考文献 距离上次阶段性回顾仅仅过去半年,感觉整个IT 行业天翻地覆慨而慷了。 时光荏苒,我自己也在芯片领域深耕了365天&…

swagger不可用

swagger不可用 问题描述问题处理测试环境外网域名测试环境内网域名思考 总结 问题描述 上周swagger还没啥问题,这周一测试突然和我说,测试环境的swagger都用不了了,然后开始找原因 问题处理 测试环境外网域名 一直跳这个弹窗,百度…

学习AJAX

AJAX 🚀 HTTP请求报文响应报文 🚄 express框架🚬 express基本使用 🚒 原生AJAX🚬 GET.HTML🚬 POST.HTML🚬 JSON.HTML🚬 nodemon工具可以帮助重启服务🚬 IE缓存问题&#…

MIT 6.829 -- L0 Background: Single-Link Communication

MIT 6.829 -- L0 Background: Single-Link Communication 前言ProblemModulation(调制) & Demodulation(解调)FramingError DetectionError RecoveryARQ Shared Media Access总结 本课程为MIT 6.829 计网课程,课程对应官网链接: Computer Networks Lecture Notes 本节对应…

操作系统——虚拟内存管理

文章目录 一、虚拟内存中的几种地址1、逻辑地址2、线性地址3、逻辑地址转线性地址4、线性地址转物理地址 二、进程与内存1、内核空间和用户空间2、内存映射3、进程内存分配与回收 早期程序直接运行在物理内存上,直接操作物理内存,这种方式存在几个问题&a…

【Python】selenium项目实战:从12306网站获取特定时间段二等座有票的车次

文章目录 一、项目背景二、页面查找1、查询条件2、定位有二等座的元素3、定位有二等座的车次信息4、CtrlF检验xpath查找的车次 三、代码实现 一、项目背景 工具: pythonpycharmselenium 12306网址: https://kyfw.12306.cn/otn/leftTicket/init?linktyp…

【GESP】2023年06月图形化四级 -- 密码合规检测

密码合规检测 【题目描述】 网站注册需要有用户名和密码,默认小猫角色和白色背景,编写程序以检查用户输入密码的有效性。 (1)合法的密码只能由a-z之间26个字母(字母不区分大小写)、0-9之间10个数字以及!@#$四个特殊字母构成。 (2)密码最短长度:6个字符,密码最大长…

通用技术 自动化测试与持续集成方案

目录 前言: 传统接口测试 接口测试自动化 接口自动化的持续集成 前言: 在现代软件开发中,自动化测试和持续集成是两个不可或缺的环节。自动化测试可以提高测试效率、减少人工错误,并确保软件的质量。持续集成则可以帮助开发团…

18.JavaWeb-JWT(登录、鉴权)

1.CSRF跨站请求伪造 跨站请求伪造(英语:Cross-site request forgery),也被称为 one-click attack 或者 session riding,通常缩写为 CSRF 或者 XSRF, 是一种挟制用户在当前已登录的Web应用程序上执行非本意的…

SOCKET编程基本原理

测试模拟环境 python 3.8—对应Pycharm 专业版 for linux 本文采用的环境是vmware + ubantu_64 先简单配置一下netstat工具 sudo apt-get install net-tools netstate基本用法 sudo netstat -at | grep 1234 // |管道函数 grep匹配正则表达式移除端口用Kill就可以了 SOCK…

Calendar类中的字段常量有哪些?

一、Calendar类介绍 Calender类是Java中用于处理日期和时间的类之一。它提供了一组方法,可以对日期和时间进行各种操作,如获取当前日期和时间、计算日期间的差值、设置特定日期和时间等。 Calendar类是一个抽象类,不能直接实例化&#xff0…