Suring开发集成部署时问题记录
前言
开发时一定要用管理员模式打开vs或者vscode进行开发,同时不要在nuget上直接下载,要去github上下载源代码调试。第一方便调试,第二surging迭代较快,nuget版本往往不是最新的。
错误
问题:fail: surging.core.dotnetty.dotnettyservermessagelistener[0] 服务主机启动失败xxx
- 使用netstat -ano命令查看报错的端口是否被占用或者是不是当前vs权限不够,不够请用管理员模式打开
-
新版本中不要使用option.usedotnettytransport();该方法已过时,如果在program中再调用的话会有冲突。
问题:generic types are not valid arg_paramname_name
接口不支持泛型类型,就是说不能这么写
[servicebundle("api/{service}")] public interface ioracledbservcie : iservicekey { task<list<t>> query<t>(string sql); task<t> executescalar<t>(string sql); task<int> execute(string sql); }
要写成这样,这还是挺坑的,不同的查询得定义不同的类型
[servicebundle("api/{service}")] public interface ioracledbservcie : iservicekey { task<list<route_service_table>> queryrouteservice(string sql); task<list<service_master_table>> queryservicemastertable(string sql); task<int> executescalar(string sql); task<int> execute(string sql); }
问题:a suitable constructor for type 'xxx' could not be located. ensure the type is concrete and services are registered for all parameters of a public constructor
出现这个错误你肯定看了网上一些吊人的文章,跑不起来就往网上放,原因是因为startup,在使用usestartup
问题:one or more errors occurred.由于目标计算机积极拒绝,无法连接 看下报错的类,比如是在这个类 问题:在代理方法上打了断点进行调试,每次都很快的返回但取不到返回值一直是null 这是由于surging熔断中的超时配置executiontimeoutinmilliseconds该值默认是一秒,调试的时候手速慢点就会立即返回,所以这个值建议设置成60000(1分钟) 问题:循环任务中在代理方法上打了断点进行调试,刚开始正常但后来每次都很快的返回但取不到返回值一直是null 同样也是熔断的限流配置maxconcurrentrequests问题,查下你是不是在循环中用了异步或者是用的parallel.foreach这类来进行循环,默认最大并发是20,超过这个值就会炸掉,设置的高一点问题解决 问题:docker中部署时配置文件内容未生效 查看你程序中是怎么引用的,可能是反斜杠的问题 docker中服务单独部署时的命令 配置说明 通过docker-compose进行部署 这种方式我只发现了 一个问题,build的内容这么写有问题 正确写法,我不知道是不是我操作有问题,反正我这边部署的时候有个问题这样写就好了 我整个开发的时候问题就这么多,可能有些没忘了,总体来说还是比较简单的。public class startup : istartup
consulservicecachemanager
中报错那就是consul没有联上,看下有没有启动consul或者是地址端口配置的对不对。在rabbitmq中报错,那就是rbmq没有联上,一样检查连接
。如果是部署在docker中出现 这个错误,那就是映射的ip和端口不对开发调试
下面附上配置字段的一些注解部署
错误写法:build.addcplatformfile("${surgingpath}|configs\\surgingsettings.json", optional: false, reloadonchange: true);
正确写法:build.addcplatformfile("${surgingpath}|configs/surgingsettings.json", optional: false, reloadonchange: true);
#docker run --name surgingserver --env mapping_ip=192.168.249.162 --env mapping_port=198 --env rootpath=/app --env
register_conn=192.168.249.162:8500 --env eventbusconnection=172.17.0.4 --env surging_server_ip=0.0.0.0 -it -p 198:198 surgingserver
mapping_ip:映射的外部ip(环境变量)
mapping_port:映射的外部端口(环境变量)
rootpath:业务模块存储的根路径(环境变量)
register_conn:注册中心地址(环境变量)
eventbusconnection:eventbus 地址(环境变量)
surging_server_ip:容器内部ip(环境变量)
service_datainteract:
build:
context: .
dockerfile: service_datainteract/dockerfile
container_name: service_datainteract
service_datainteract:
build:
context: ./service_datainteract
dockerfile: dockerfile
container_name: service_datainteract
结语
另外比较可惜的是surging出完2.0就不更新了,作者跑路了。。。。后面只能自己在上面完善了
微信关注我哦!(转载注明出处)
下一篇: HashSet源码分析