首先访问https://github.com/dromara/soul 对该仓库进行star和watch,做为一个网关使用的新手。须要在后续关注soul的开发动向,把他更好的用在工做当中
随后将该仓库fork到本身的github中。方便本身后续进行代码的学习和注释。而后对本身fork的仓库进行clonemysql
git clone git@github.com:zhendiao/soul.git
而后将本身的代码导入到IDEA当中,首先观察Soul项目的目录结构
咱们能够很明显的猜到Soul-admin为该网关的管理控制台项目。打开配置文件,虽然能够提供内置的H2数据库做为数据源,可是为了使用方便,咱们仍是使用MySQL做为数据源,建议MySQL版本为mysql5。修改mysql的配置,无需手动建立数据库,启动以后自动建立了数据库。
git
能够看到启动以后的界面
github
soul-bootrap做为拦截外部请求的核心层,目前默认的数据同步方式为websocket配置,配置以下web
soul : file: enabled: true corss: enabled: true dubbo : parameter: multi sync: websocket : urls: ws://localhost:9095/websocket
同时注释的代码中也包含了其余诸如Zookeeper,nacos,http等同步方式。在后面几天的尝试中,会尝试其余几种方式面试
参考官网进行http(springboot)方式进行最简单的代理环境搭建,首先新建一个springboot项目,配置以下spring
soul: # Soul 针对 SpringMVC 的配置项,对应 SoulHttpConfig 配置类 http: admin-url: http://127.0.0.1:9095 # Soul Admin 地址 context-path: /soulboot # 设置在 Soul 网关的路由前缀,例如说 /order、/product 等等。 # 后续,网关会根据该 context-path 来进行路由 app-name: soulboot # 应用名。未配置状况下,默认使用 `spring.application.name` 配置项 port: 7070 #你本项目的启动端口 full: false # 设置true 表明代理你的整个服务,false表示代理你其中某几个controller server: port: 7070
新建一个测试controllersql
package org.dromara.soul.boot.controller; import org.dromara.soul.client.springmvc.annotation.SoulSpringMvcClient; import org.springframework.web.bind.annotation.*; @RestController @RequestMapping("/user") public class HomeController { @GetMapping("/get") @SoulSpringMvcClient(path = "/user/get", desc = "得到用户详细") public String getUser(@RequestParam("id") Integer id) { return "DEMO:" + id; } }
经过访问soul-boostrap的端口搭配本项目的路由地址便可实现成功访问
数据库
欢迎搜索关注本人与朋友共同开发的微信面经小程序【大厂面试助手】和公众号【微瞰技术】bootstrap