详解JavaEE中Apollo安装使用小结

网友投稿 365 2022-08-22


详解JavaEE中Apollo安装使用小结

目录一、安装mysql5.7.37(主机:192.168.233.128,用户/密码:root):二、Apollo安装/启动(centos7)(主机:192.168.233.128):三、Web应用接入Apollo(SpringBoot):

说明:

Apollo是配置管理中心,和SpringCloud-Config实现的功能有点相似。

一、安装MySQL 5.7.37(主机:192.168.233.128,用户/密码:root):

1.下载mysql-5.7.37-1.el7.x86_64.rpm-bundle.tar,并上传到centos7:

https://dev.mysql.com/downloads/mysql/

解压mysql-5.7.37-1.el7.x86_64.rpm-bundle.tar(cd到/root目录):

[root@localhost ~]# tar -xvf mysql-5.7.37-1.el7.x86_64.rpm-bundle.tar

2.安装依赖:

[root@localhost ~]# yum -y install libaio

[root@localhost ~]# yum -y install perl

[root@localhost ~]# yum -y install net-tools

3.安装mysql:

[root@localhost ~]# rpm -ivh mysql-community-common-5.7.37-1.el7.x86_64.rpm

[root@localhost ~]# rpm -ivh mysql-community-libs-5.7.37-1.el7.x86_64.rpm

[root@localhost ~]# rpm -ivh mysql-community-client-5.7.37-1.el7.x86_64.rpm

[root@localhost ~]# rpm -ivh mysql-community-server-5.7.37-1.el7.x86_64.rpm

[root@localhost ~]# rpm -ivh mysql-community-libs-compat-5.7.37-1.el7.x86_64.rpm

4.启动:

[root@localhost ~]# service mysqld start

5.查看临时密码:

[root@localhost ~]# grep password /var/log/mysqld.log

6.登录(在Enter password输入上方查看的密码):

[root@localhost ~]# mysql -u root -p

Enter password:

7.修改密码(密码:root):

mysql> ALTER USER 'root'@'localhost' IDENTIFIED WITH MYSQL_NATIVE_PASSWORD BY 'Root123456=';

mysql> SET GLOBAL validate_password_length=2;

mysql> SET GLOBAL validate_password_policy=0;

mysql> ALTER USER 'root'@'localhost' IDENTIFIED WITH MYSQL_NATIVE_PASSWORD BY 'root';

8.允许远程访问:

mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'root' WITH GRANT OPTION;

二、Apollo安装/启动(centos7)(主机:192.168.233.128):

1.下载apollo-quick-start-1.9.2.zip:

https://apolloconfig.com/#/zh/deployment/quick-start?id=%e4%ba%8c%e3%80%81%e5%ae%89%e8%a3%85%e6%ad%a5%e9%aa%a4

2.创建ApolloPortalDB、ApolloConfigDB数据库:

(1)使用Navicat连接mysql5,创建ApolloPortalDB、ApolloConfigDB数据库:

注:ApolloPortalDB在生产环境部署,而ApolloConfigDB需要每个环境部署一套。

(2)导入apolloportaldb.sql到ApolloPortalDB数据库(sql文件在apollo-quick-start-1.9.2/sql目录中):

使用Navicat右击ApolloPortalDB数据库,运行 SQL 文件,选择apolloportaldb.sql,点开始按钮。

(3)导入apolloconfigdb.sql到ApolloConfigDB数据库(sql文件在apollo-quick-start-1.9.2/sql目录中):

使用Navicat右击ApolloConfigDB数据库,运行 SQL 文件,选择apolloconfigdb.sql,点开始按钮。

3.安装Apollo:

(1)将apollo-quick-start-1.9.2.zip上传到/usr/local/apollo目录(mkdir /usr/local/apollo)。

(2)解压apollo-quick-start-1.9.2.zip(cd /usr/local/apollo/):

[root@localhost apollo]# unzip apollo-quick-start-1.9.2.zip

(3)配置ApolloPortalDB、ApolloConfigDB数据库连接信息:

[root@localhost apollo]# vi demo.sh

修改如下内容:

#ApolloConfigDB连接信息

apollo_config_db_url="jdbc:mysql://192.168.233.128:3306/ApolloConfigDB?characterEncoding=utf8&serverTimezone=Asia/Shanghai"

apollo_config_db_username=root

apollo_config_db_password=root

#ApolloPortalDB连接信息

apollo_portal_db_url="jdbc:mysql://192.168.233.128:3306/ApolloPortalDB?characterEncoding=utf8&serverTimezone=Asia/Shanghai"

apollo_portal_db_username=root

apollo_portal_db_password=root

...

# meta server url

config_server_url=http://192.168.233.128:8080

admin_server_url=http://192.168.233.128:8090

...

portal_url=http://192.168.233.128:8070

4.启动/停止Apollo:

[root@localhost apollo]# ./demo.sh start[root@localhost apollo]# ./demo.sh stop

5.打开Apollo首页(用户apollo,密码admin):

http://192.168.233.128:8070

三、Web应用接入Apollo(SpringBoot):

1.在Apollo中创建应用:

(1)在首页,点左上角"创建应用",输入AppId值等(此处AppId与待接入应用application.yml的app.id对应):

(2)进入创建的应用,点击Key/Value列表的右上角"新增配置",添加Key和Value:

(3)创建Key+Value后,回到Key/Value列表中,点右上角靠左的"发布"按钮生效:

2.Web工程中配置Apollo信息:

(1)添加apollo依赖:

com.ctrip.framework.apollo

apollo-client

1.9.2

com.ctrip.framework.apollo

apollo-openapi

1.9.2

(2)配置app.id与app.meta,在application.yml中:

...

app:

id: apollo #apollo应用ID(必须与Apollo网页上创建项目时定义的应用Id一致)

apollo:

meta: http://192.168.233.128:8080 #apollo服务器地址

autoUpdateInjectedSpringProperties: true #false时@Value("${key1}")值不会自动更新,默认true自动更新

#cache-dir: /opt/data/some-cache-dir #自定义本地缓存路径,默认为/opt/data/{appId}/config-cache

access-key:

secret: 838fe62c502a43e2b70a31d7c7156f10 #配置访问密钥,在Apollo首页-管理密钥中创建密钥

property:

names:

cache:

enable: true #开启propertyNames缓存

bootstrap:

enabled: true #开启 Apollo

namespaces: application #可以注入多个命名空间,以逗号分隔

#eagerLoad:

# enabled: true #将apollo初始化放在日志系统初始化之前

(3)Application启动类添加@EnableApolloConfig注解:

@SpringBootApplication

@EnableApolloConfig //开启Apollo

public class ApolloApplication kfpSx{

public static void main(String[] args) {

SpringApplication.run(ApolloApplication.class);

}

}

(4)Config方式获取apollo配置中心的配置:

@Configuration

public class ApolloConfig {

@Value("${key1}")//从apollo配置中心获取添加的key1

public String key1;

}

(5)获取key1并打印的测试Conrtoller:

@RestController

public class UserController {

@Autowired

private ApolloConfig apolloConfig;

@RequestMapping("/user")

@ResponseBody

public String user(){

return apolloConfig.key1;

}

}

3.启动Web应用,需要添加Apollo环境+地址参数:

(1)IntelliJ IDEA方式,Edit Configurations -> 左侧Application中选中ApolloApplication,右侧Configuration选项卡中,在VM options中填入:

-Dapollo.meta=http://192.168.233.128:8080 -Denv=dev

(2)运行jar包方式,展开IntelliJ IDEA右侧Maven -> 找到apollo模块Lifecycle菜单,分别双击clean、install,将target目录下生成的apollo.jar上传到centos7,并使用java命令启动:

[root@localhost ~]# java -jar -Dapollo.meta=http://192.168.233.128:8080 -Denv=dev apollo.jar &

(3)访问Web应用"/user"接口显示获取到的key1值可以看到效果(不停止Web应用,修改Apollo配置中心的key1值,重新发布,再刷新以下接口,可以看到值已经变成新的了):

http://192.168.233.128:10006/user


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:springcloud配置ssh的问题及解决方法
下一篇:java如何反编译jar包并修改class文件重新打包
相关文章

 发表评论

暂时没有评论,来抢沙发吧~