mysql网关源码_高性能网关Soul源码调试环境搭建

拉取代码,修改配置

首先访问https://github.com/dromara/soul 对该仓库进行star和watch,作为一个网关使用的新手。需要在后续关注soul的开发动向,把他更好的用在工作当中

随后将该仓库fork到自己的github中。方便自己后续进行代码的学习和注释。然后对自己fork的仓库进行clone

git clone git@github.com:zhendiao/soul.git

然后将自己的代码导入到IDEA当中,首先观察Soul项目的目录结构

65762d6c9312

file

我们可以很明显的猜到Soul-admin为该网关的管理控制台项目。打开配置文件,虽然可以提供内置的H2数据库作为数据源,但是为了使用方便,我们还是使用MySQL作为数据源,建议MySQL版本为mysql5。修改mysql的配置,无需手动创建数据库,启动之后自动创建了数据库。

65762d6c9312

file

可以看到启动之后的界面

65762d6c9312

file

网关核心层Soul-Bootstrap

soul-bootrap作为拦截外部请求的核心层,目前默认的数据同步方式为websocket配置,配置如下

soul :

file:

enabled: true

corss:

enabled: true

dubbo :

parameter: multi

sync:

websocket :

urls: ws://localhost:9095/websocket

同时注释的代码中也包含了其他诸如Zookeeper,nacos,http等同步方式。在后面几天的尝试中,会尝试其他几种方式

测试项目

参考官网进行http(springboot)方式进行最简单的代理环境搭建,首先新建一个springboot项目,配置如下

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

新建一个测试controller

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的端口搭配本项目的路由地址即可实现成功访问

65762d6c9312

file

目前疑问

配置的端口为admin的端口,soul-bootstrap如何同步数据并代理的

欢迎关注和点赞

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值