☀️手把手教你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、发布
选择发布版本