☀️手把手教你Camel 环境搭建☀️《❤️记得收藏❤️》

2021-08-18 12:26:47 浏览数 (1)

☀️手把手教你Camel 环境搭建☀️《❤️记得收藏❤️》

  • 目录
  • ?开讲啦!!!!?️‍?
  • :person_fencing:1、Vagrant 环境
    • ?1.1、Vagrant 是什么
    • ?1.2、Vagrant 能做什么
    • ? 1.3、Vagrant 相关软件下载
    • ?1.4、Vagrant 配置环境变量(Windows)
      • ?1.4.1、VirtualBox
      • ?1.4.2、Vagrant
    • ?1.5、启动 Vagrant
      • ?1.5.1、创建 vagrant 环境目录
      • ?1.5.2、vagrant box 下载
      • ?1.5.3、使用 box 方式安装系统
      • ?1.5.4、初始化和 Vagrantfile
      • ?1.5.5、public_network 配置
      • ?1.5.6、启动虚拟机
    • ?1.6、使用 ssh 登录到虚拟机
  • :horse_racing:2、camel 环境
    • ?2.1、admin 端
      • ?2.1.1、系统初始化和下载 camel
      • ?2.1.2、安装 mariadb
      • ?2.1.3、安装 mongodb
      • ?2.1.4、配置 camel-admin 和生成 camel-admin 的 war 包
      • ?2.1.5、安装 tomcat
      • ?2.1.6、安装 Dengine
      • ?2.1.7、启动 Dengine 和 tomcat
      • ?2.1.8、访问管理端首页
    • ?2.2、agent 端(agent1/agent2)
      • ?2.2.1、系统初始化
      • ?2.2.2、安装依赖包
      • ?2.2.3、安装 JDK
      • ?2.2.4、添加 dns
      • ?2.2.5、运行 camel-agent
      • ?2.2.6、安装 tomcat(可选)
      • ?2.2.7、安装 Dengine
      • ?2.2.8、启动 Dengine
    • :woman_playing_handball:3、camel 使用
      • ?3.1、创建 nginx 集群
      • ?3.2、nginx 集群重命名
      • ?3.3、nginx 集群添加节点
      • ?3.4、新增集群
      • ?3.5、集群重命名
      • ?3.6、新增站点
      • ?3.7、站点命名
      • ?3.8、映射规则
      • ?3.9、预览
      • ?3.10、创建发布版本
      • ?3.11、发布
      • ?3.12、最终发布页面
  • ?️‍?关注苏州程序大白,持续更新技术分享。谢谢大家支持?️‍?
  • ?️‍?关注苏州程序大白,持续更新技术分享。谢谢大家支持?️‍?

目录

?开讲啦!!!!?️‍?

?1、Vagrant 环境

?1.1、Vagrant 是什么

Vagrant是一款用来构建虚拟开发环境的工具,它底层支持 VirtualBox、VMware 甚至 AWS 作为虚拟机系统,提供易于配置,重复性好,便携式的工作环境。也可以和 puppet,chef 结合,实现虚拟机管理的自动化。

?1.2、Vagrant 能做什么

统一开发环境。一次配置打包,统一分发给团队成员,统一团队开发环境,解决诸如“编码问题”,“缺少模块”,“配置文件不同”带来的问题;

避免重复搭建开发环境。新员工加入,不用浪费时间搭建开发环境,快速加入开发,减少时间成本的浪费;

多个相互隔离开发环境。可以在不用box里跑不同的语言,或者编译安装同一语言不同版本,搭建多个相互隔离的开发环境,卸载清除时也很快捷轻松。

? 1.3、Vagrant 相关软件下载

  • 下载 vagrant
  • 下载 VirtualBox

注意:以下以安装在 Windows 上为例,VirtualBox 和 Vagrant 不要装在同一分区里,Vagrant 默认选项安装到C盘。

?1.4、Vagrant 配置环境变量(Windows)

?1.4.1、VirtualBox

VirtualBox:将 %VirtualBox_homt% 添加到 Path 中,这样 Vagrant 才能被识别:

  • 变量名:VBOX_MSI_INSTALL_PATH
  • 变量值:D:软件VirtualBox(根据自己安装目录)

?1.4.2、Vagrant

Vagrant:安装成功后,自动在 Path 中添加 %Vagrant_home%/bin,检查一下。

  • 变量名:Path
  • 变量值:…;C:HashiCorpVagrantbin

?1.5、启动 Vagrant

?1.5.1、创建 vagrant 环境目录

进入运行命令模式,创建测试文件夹(vagrant 环境所在目录)

进创建 vagrantdemo 目录

代码语言:javascript复制
C:UsersAdministrator>md vagrantdemo
C:UsersAdministrator>cd vagrantdemo

?1.5.2、vagrant box 下载

box 是一个zip包,包含了 vagrant 的配置信息和 VirtualBox 的虚拟机镜像文件。

下载 box

?1.5.3、使用 box 方式安装系统

命令格式

代码语言:javascript复制
vagrant box add "box_name" remoteUrl or localFile

box_name 可以是任意字符,用于标识 box。 使用 remoteUrl(远程地址)添加 box。

代码语言:javascript复制
vagrant box add "centos7" https://github.com/holms/vagrant-centos7-box/releases/download/7.1.1503.001/CentOS-7.1.1503-x86_64-netboot.box

这种方式需要即时下载,较慢,建议下载下来 box,在本地添加。

或是使用 localFile(本地 box 文件)添加 box。

后面加绝对路径或进入同层目录。

代码语言:javascript复制
agrant box add "centos7" CentOS-7.1.1503-x86_64-netboot.box

?1.5.4、初始化和 Vagrantfile

代码语言:javascript复制
vagrant init "box_name"

初始化后会在当前目录(C:UsersAdministratorvagrantdemo)生成以一个 Vagrantfile 文件

Vagrantfile 详细使用请自行查阅资料或官方文档。

这里环境使用的 Vagrantfile,可以复制使用。

代码语言:javascript复制
# -*- mode: ruby -*-
# vi: set ft=ruby :
Vagrant.configure("2") do |config|
config.vm.define :admin do |admin|
admin.vm.provider "virtualbox" do |v|
v.customize ["modifyvm", :id, "--name", "admin", "--memory", "1024"]
end
admin.vm.box = "centos7"
admin.vm.hostname = "camel-admin"
admin.vm.network "public_network"
end
config.vm.define :agent1 do |agent1|
agent1.vm.provider "virtualbox" do |v|
v.customize ["modifyvm", :id, "--name", "agent1", "--memory", "512"]
end
agent1.vm.box = "centos7"
agent1.vm.hostname = "agent1"
agent1.vm.network "public_network"
end
config.vm.define :agent2 do |agent2|
agent2.vm.provider "virtualbox" do |v|
v.customize ["modifyvm", :id, "--name", "agent2", "--memory", "512"]
end
agent2.vm.box = "centos7"
agent2.vm.hostname = "agent2"
agent2.vm.network "public_network"
end
end

?1.5.5、public_network 配置

配置 Virtualbox 网络,使 vagrant 虚拟机获得本地 dhcp 分发的 ip。

添加 nat 网络

编辑 nat 网络

?1.5.6、启动虚拟机

vagrant up

启动后会打开 3 台虚拟机 admin,agent1,agent2。

对应 127.0.0.1 的 2222、2200、2201 端口。

并获得本地 ip 地址。

?1.6、使用 ssh 登录到虚拟机

windows 默认没有 ssh 命令,可以安装 babun 或 cmder

使用如下命令连接

代码语言:javascript复制
C:UsersAdministratorvagrantdemo>vagrant ssh

下面使用xshell连接,初始账号密码都是vagrant

连接 camel-admin

代码语言:javascript复制
ssh 127.0.0.1 2222

连接后使用 sudo passwd root 修改 root 密码

使用 ip a 查看获取到的局域网 dhcp ip

再次登录

ssh 192.168.1.210 连接 admin

连接 agent1

代码语言:javascript复制
ssh 127.0.0.1 2200

连接agent2

代码语言:javascript复制
ssh 127.0.0.1 2201

?2、camel 环境

admin 端需要安装 camel-admin 和 Dengine

agent 端需要安装 camel-agent 和 Dengine

?2.1、admin 端

?2.1.1、系统初始化和下载 camel

清除 vagrant 默认防火墙策略

代码语言:javascript复制
chmod 755 /etc/rc.d/rc.local
echo "/usr/sbin/iptables -F" >> /etc/rc.local
iptables -F

关闭也可以

代码语言:javascript复制
systemctl stop firewalld
systemctl disable firewalld

依赖包安装

代码语言:javascript复制
yum install -y vim unzip maven net-tools git gcc gcc-c   automake autoconf 
libtool make ncurses-devel zlib zlib-devel libtermcap-devel libevent-devel readline-devel patch

下载 camel-master.zip 项目地址

代码语言:javascript复制
nzip camel-master.zip

?2.1.2、安装 mariadb

代码语言:javascript复制
yum -y install mariadb mariadb-server
systemctl start mariadb
systemctl enable mariadb

mariadb 初始化

代码语言:javascript复制
mysql -uroot
MariaDB [(none)]> grant all on *.* to root@localhost identified by '123456';
MariaDB [(none)]> flush privileges;
MariaDB [(none)]> create database camel;
MariaDB [(none)]> use camel;
MariaDB [(none)]>
source /root/camel-master/camel-admin/src/main/resources/init-data/create_table.sql

?2.1.3、安装 mongodb

下载 mongodb

注意:下载 3.0.7 版本,3.0.7 以上版本有问题最新 3.4.1 启动报错

mongodb 初始化

代码语言:javascript复制
tar zxvf mongodb-linux-x86_64-rhel70-3.0.7.tgz
mv mongodb-linux-x86_64-rhel70-3.0.7 mongodb
cd mongodb
mkdir db logs
代码语言:javascript复制
cd bin
vim mongodb.conf
dbpath=/root/mongodb/db
logpath=/root/mongodb/logs/mongodb.log
port=27017
fork=true
nohttpinterface=true

启动 mongodb

代码语言:javascript复制
/root/mongodb/bin/mongod --bind_ip localhost -f /root/mongodb/bin/mongodb.conf

mongodb 建库

代码语言:javascript复制
/root/mongodb/bin/mongo
> use camel_runtime
switched to db camel_runtime
> db.movie.insert({"name":"tutorials yiibai"})
WriteResult({ "nInserted" : 1 })
> use camel_nginx_log
switched to db camel_nginx_log
> db.movie.insert({"name":"tutorials yiibai"})
WriteResult({ "nInserted" : 1 })
> use camel_config
switched to db camel_config
> db.movie.insert({"name":"tutorials yiibai"})
WriteResult({ "nInserted" : 1 })
> show dbs
admin 0.000GB
camel_config 0.000GB
camel_nginx_log 0.000GB
camel_runtime 0.000GB
local 0.000GB
> exit

?2.1.4、配置 camel-admin 和生成 camel-admin 的 war 包

camel-admin 配置文件修改

代码语言:javascript复制
grep -r "/data/appdatas/camel/" ./*
./src/main/resources/spring/applicationContext-properties.xml: <value>file:/data/appdatas/camel/jdbc-mysql.properties</value>
./src/main/resources/spring/applicationContext-properties.xml: <value>file:/data/appdatas/camel/mongo.properties</value>
./src/main/resources/spring/applicationContext-properties.xml: <value>file:/data/appdatas/camel/camel.properties</value>
代码语言:javascript复制
mkdir -p /data/appdatas/camel/
cp /root/camel-master/camel-admin/src/main/resources/init-data/camel.properties /data/appdatas/camel/
vim camel.properties
# threshold of local nginx config check
local.nginx.config.check=true
cp /root/camel-master/camel-admin/src/main/resources/init-data/jdbc-mysql.properties /data/appdatas/camel/
vim /data/appdatas/camel/jdbc-mysql.properties
jdbc.driverClassName=com.mysql.jdbc.Driver
jdbc.username=root
jdbc.password=123456
jdbc.maxPoolSize=50
jdbc.minPoolSize=1
jdbc.initialPoolSize=1
jdbc.idleConnectionTestPeriod=1800
jdbc.maxIdleTime=3600
jdbc.checkoutTimeout=5000
jdbc.url=jdbc:mysql://127.0.0.1:3306/camel?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&noAccessToProcedureBodies=true&socketTimeout=5000&connectTimeout=5000

红色camel为之前mariadb新建的数据库名

代码语言:javascript复制
cp src/main/resources/init-data/mongo.properties /data/appdatas/camel/
vim /data/appdatas/camel/mongo.properties
mongodb.url=127.0.0.1:27017
mongodb.dbname_config=camel_config
mongodb.dbname_nginx_log=camel_nginx_log
mongodb.dbname_runtime=camel_runtime
isCluster=false
connections-per-host=1800
slave-ok=false

添加 dns

否则后面下载无法解析

代码语言:javascript复制
echo "nameserver 8.8.8.8" >> /etc/resolv.conf

构建 camel-admin

代码语言:javascript复制
cd /root/camel-master/camel-admin/
mvn clean compile

时间较长,最后看到 BUILD SUCCESS 构建成功

生成 camel-admin 的 war 包

代码语言:javascript复制
cd /root/camel-master/camel-admin/
mvn install package -Dmaven.test.skip=true

在 /root/camel-master/camel-admin/target/ 目录下生成 war 包

?2.1.5、安装 tomcat

这里使用 tomcat7,jdk 在之前 camel-admin 构建过程中已安装,为 openjdk将之前生成的 camel-admin 的 war 包放到 tomcat 项目目录。

代码语言:javascript复制
cp camel-admin-1.0.0.war /opt/apache-tomcat-7.0.59/webapps/

?2.1.6、安装 Dengine

注意:Dengine 默认安装到 /usr/loca/nginx,安装 Dengine 之前,删除系统中安装在 /usr/loca/nginx 目录的 nginx,其他 nginx 不要安装到 /usr/loca/nginx 目录

代码语言:javascript复制
cd /root/camel-master/Dengine/
./install_dengine

权限确认,/usr/local/nginx/conf/phoenix-slb/ 权限 777

代码语言:javascript复制
chmod 777 /usr/local/nginx/conf/phoenix-slb/

访问策略配置

代码语言:javascript复制
vim /usr/local/nginx/conf/nginx_status.conf
req_status_zone server "$host:$server_addr:$server_port" 10M;
check_shm_size 50M;
req_status server;
server {
  listen 6666;
  server_name aaabbbccc;
  location /status {
    check_status;
    access_log off;
    allow 192.168.0.210;
    # deny all;
  }
  location /degrade{
    upstream_degrade_interface;
    access_log off;
    allow 192.168.0.210;
    # deny all;
  }
  location / {
    return 444;
  }
}
server {
  listen 80 default_server;
  server_name aaabbbccc;
  location /status {
    echo "ok";
    default_type text/plain;
    access_log off;
    allow 192.168.0.210;
    # deny all;
  }
  location /reqstatus {
    req_status_show;
    access_log off;
    allow 192.168.0.210;
    # deny all;
  }
  location / {
    return 444;
  }
  error_page 404 403 =444 @static;
  location @static{
    return 444;
  }
}

?2.1.7、启动 Dengine 和 tomcat

启动 Dengine

代码语言:javascript复制
/usr/local/nginx/sbin/nginx

开机自启动

代码语言:javascript复制
echo "/usr/local/nginx/sbin/nginx" >> /etc/rc.local

启动 tomcat

代码语言:javascript复制
cd /opt/apache-tomcat-7.0.59/bin/
./startup.sh

开机自启动

代码语言:javascript复制
echo "/opt/apache-tomcat-7.0.59/bin/startup.sh" >> /etc/rc.local

?2.1.8、访问管理端首页

http://192.168.0.210:8080/camel-admin-1.0.0/

?2.2、agent 端(agent1/agent2)

?2.2.1、系统初始化

清除 vagrant 默认防火墙策略

代码语言:javascript复制
chmod 755 /etc/rc.d/rc.local
echo "/usr/sbin/iptables -F" >> /etc/rc.local
iptables -F

关闭也可以

代码语言:javascript复制
systemctl stop firewalld
systemctl disable firewalld

?2.2.2、安装依赖包

代码语言:javascript复制
yum -y install maven git gcc gcc-c   automake autoconf libtool make ncurses-devel 
zlib zlib-devel libtermcap-devel libevent-devel readline-devel patch

?2.2.3、安装 JDK

代码语言:javascript复制
yum search java | grep -i --color JDK
代码语言:javascript复制
yum install java-1.7.0-openjdk

?2.2.4、添加 dns

代码语言:javascript复制
vim /etc/resolv.conf
nameserver 8.8.8.8

?2.2.5、运行 camel-agent

代码语言:javascript复制
cd /root/camel-master/camel-agent

运行 agent

代码语言:javascript复制
mvn spring-boot:run > /root/camel-agent.out 2>&1 &

生成 war 包(可选)

代码语言:javascript复制
mvn clean package

可以将 /root/camel-master/camel-agent/target 目录下生成的 war 包放到 tomcat 工程目录运行

?2.2.6、安装 tomcat(可选)

注意:如果已经使用 mvn spring-boot:run 方式启动 agent,跳过此步

这里使用 tomcat7,jdk 为 java-1.7.0-openjdk

将之前生成的 camel-admin 的 war 包放到 tomcat 项目目录

代码语言:javascript复制
cp /root/camel-master/camel-agent/target/camel-agent-1.0.0.war /opt/apache-tomcat-7.0.59/webapps/
cd /opt/apache-tomcat-7.0.59/bin
./startup.sh

?2.2.7、安装 Dengine

注意:Dengine 默认安装到 /usr/loca/nginx,安装 Dengine 之前,删除系统中安装在 /usr/loca/nginx 目录的 nginx,其他 nginx 不要安装到 /usr/loca/nginx 目录。

代码语言:javascript复制
cd /root/camel-master/Dengine/
./install_dengine

权限确认,/usr/local/nginx/conf/phoenix-slb/ 权限 777

代码语言:javascript复制
chmod 777 /usr/local/nginx/conf/phoenix-slb/

访问策略配置

代码语言:javascript复制
vim /usr/local/nginx/conf/nginx_status.conf
req_status_zone server "$host:$server_addr:$server_port" 10M;
check_shm_size 50M;
req_status server;
server {
  listen 6666;
  server_name aaabbbccc;
  location /status {
    check_status;
    access_log off;
    allow 192.168.0.210;
    # deny all;
  }
  location /degrade{
    upstream_degrade_interface;
    access_log off;
    allow 192.168.0.210;
    # deny all;
  }
  location / {
    return 444;
  }
}
server {
  listen 80 default_server;
  server_name aaabbbccc;
  location /status {
    echo "ok";
    default_type text/plain;
    access_log off;
    allow 192.168.0.210;
    # deny all;
  }
  location /reqstatus {
    req_status_show;
    access_log off;
    allow 192.168.0.210;
    # deny all;
  }
  location / {
    return 444;
  }
  error_page 404 403 =444 @static;
  location @static{
    return 444;
  }
}
cd /root/camel-master/Dengine/
./install_dengine

?2.2.8、启动 Dengine

启动 Dengine

代码语言:javascript复制
/usr/local/nginx/sbin/nginx

开机自启动

代码语言:javascript复制
echo "/usr/local/nginx/sbin/nginx" >> /etc/rc.local

开机自启动 camel-agent

代码语言:javascript复制
echo " mvn spring-boot:run > /root/camel-agent.out 2>&1 &" >> /etc/rc.local

?‍♀3、camel 使用

?3.1、创建 nginx 集群

?3.2、nginx 集群重命名

?3.3、nginx 集群添加节点

?3.4、新增集群

?3.5、集群重命名

?3.6、新增站点

?3.7、站点命名

?3.8、映射规则

编辑

详细

添加新指令

保存

?3.9、预览

?3.10、创建发布版本

?3.11、发布

选择发布版本

?3.12、最终发布页面

0 人点赞