- C#.VB.NET多线程,多用户下独立锁和全局锁的区别
专注VB编程开发20年
php开发语言c#.net
以下代码,每个客户端都分配了一个锁吗?'用户WebSocket信息类PublicClassUserWebSocketInfoPublicPropertySessionIDAsStringPublicPropertyWebSocketAsWebSocketPublicPropertyLastResponseTimeAsDateTimePublicPropertyPendingHeartbeatCou
- C# TCP心跳机制:让客户端拥有“不死之身”,网络波动?不存在的!
墨夶
C#学习资料网络c#tcp/ip
1.TCP连接的“心脏病”与心跳的救赎监控面板上的“连接断开”提示,突然发现游戏服务器的玩家都在“消失”——原来TCP连接在深夜的网络波动中“猝死”了!2.从“心跳骤停”到“永不掉线”的重生之路2.1原理篇:心跳机制的“三重防护”核心概念:心跳包:客户端定时发送的“我还在”信号(如{"type":"heartbeat"})超时检测:如果超过HeartbeatTimeout秒未收到心跳响应,触发断开
- 游戏开发中,为什么在长连接服务器和客户端之间需要加入心跳机制?
晚夜微雨问海棠呀
服务器智能路由器网络
在游戏开发中,长连接服务器与客户端之间加入心跳机制(HeartbeatMechanism)是保障网络通信稳定性、可靠性的关键设计,其核心目的是解决长连接在复杂网络环境下的“假活”问题。以下从技术原理、实际需求、应用场景三个维度展开分析:一、核心技术原因:应对网络环境的不确定性检测连接真实状态长连接(如TCP)在物理断开(如客户端断网、路由器重启)时,服务器无法立即感知。心跳机制通过定时发送轻量级数
- 使用Nginx + Keepalived配置实现Web站点高可用方案
夜影风
linux系统管理Architecturenginx前端智能路由器
1.概述1.1Keepalived介绍Keepalived是一个基于VRRP协议来实现的服务高可用方案,可以利用其来避免IP单点故障,类似的工具还有heartbeat、corosync、pacemaker。但是它一般不会单独出现,而是与其它负载均衡技术(如LVS、HAProxy、Nginx)一起工作来达到集群的高可用。VRRP(VirtualRouterRedundancyProtocol),即虚
- VUE中的websocket的封装
HarryHY
#vue2.0websocketvue.jsjavascript
socket.js部分varwebsock=null;letrec;//断线重连后,延迟5秒重新创建WebSocket连接rec用来存储延迟请求的代码letisConnect=false;//连接标识避免重复连接letcheckMsg="heartbeat";//心跳发送/返回的信息服务器和客户端收到的信息内容如果如下就识别为心跳信息不要做业务处理varglobalCallback=functio
- 设计永不宕机的 K8s 集群的策略方法
奔向理想的星辰大海
云原生kubernetes容器云原生
一、控制平面高可用设计1.多Master节点部署•跨可用区部署优化:a.AWS示例:使用topology.kubernetes.io/zone标签强制etcd节点分布在3个AZ。b.性能调优参数:#etcd配置(/etc/etcd/etcd.conf)ETCD_HEARTBEAT_INTERVAL="500ms"ETCD_ELECTION_TIMEOUT="2500ms"ETCD_MAX_REQU
- YashanDB 报错 YAS-07301:通过 dblink 查询 Oracle 超时?可能是系统资源瓶颈
数据库
【问题描述】某用户在使用yasql通过dblink查询Oracle数据时,执行以下语句:select1fromdual@link_oracle;报错如下:YAS-07301externalmoduletimeout,reason:yex_serverheartbeattimeout【问题影响】所有版本的YashanDB均可能受影响;导致dblink功能失效,外部数据源无法访问。【根本原因】查看日志
- 【前端】【面试】实时聊天系统使用 WebSocket 时,你是怎样保证消息的实时性和稳定性的?
患得患失949
面试考题专栏(前后端)前端面试websocket
在构建实时聊天系统时,使用WebSocket确实可以大大提升“实时性体验”,但仅使用WebSocket不足以保证消息稳定性与可靠性。为了确保消息既“实时”又“稳定”,我在多个实际项目中从以下几个方面进行保障:使用WebSocket构建实时聊天系统时,如何保证消息的实时性与稳定性一、连接稳定性保障1.心跳机制(Heartbeat)问题:客户端断网/浏览器挂起后,服务端无法立刻感知连接断开。✅解决方案
- Vert.x学习(五)—— SockJS,搭建客户端,与后端服务器进行通信
艾露z
框架学习java后端web前端
SockJS定义:为前端提供类似WebSocket的接口与后端的vertx服务器创建连接SockJSHanlder用于在服务端接收客户端的请求//基本配置SockJSHandlerOptionsoptions=newSockJSHandlerOptions().setHeartbeatInterval(2000)//配置允许的客户端源.setOrigin("http://localhost:517
- CEPH OSD_SLOW_PING_TIME_FRONT/BACK 警告处理
时空无限
cephceph
cephconfigsetmgrmon_warn_on_slow_ping_time2000说明:mon_warn_on_slow_ping_time该值默认为0,那么只要osd心跳超过mon_warn_on_slow_ping_ratioofosd_heartbeat_grace.也就是超过mon_warn_on_slow_ping_ratio和mon_warn_on_slow_ping_rat
- 心跳机制简介
榴月~
tcp/ip
心跳机制心跳机制(HeartbeatMechanism)是一种用于监控和维护计算机系统、网络和分布式系统中各个节点之间连接状态的技术。它通过周期性地发送信号(即“心跳”)来确认系统组件之间的活跃性和可用性。如果某个节点没有在预期时间内收到心跳信号,它就会认为连接可能已经断开或某个节点可能出现故障,从而采取相应的措施,比如重新连接或进行故障处理。心跳机制广泛应用于以下几个方面:分布式系统:在分布式系
- heartbeat + pacemaker实现pg流复制自动切换(二)
weixin_34308389
数据库网络运维
五、测试5.1备节点失效在node2上杀死postgres数据库进程,模拟备节点上数据库崩溃:[root@node2 ~]# killall -9 postgres查看此时集群状态:[root@node1 ~]# crm_mon -Afr1============Last updated: Mon Jan 27 08:36:49 2014Stack: HeartbeatCurrent DC: no
- 自用基于 TypeScript 的 WebSocket 客户端封装
Luke Paul Na
typescriptwebsocketjavascript
代码本体exportinterfaceIWSOptions{url?:string;sendContent?:string|object;token?:string;reconnectInterval?:number;heartbeatInterval?:number;heartbeatContent?:string|object;onOpen?:()=>void;onMessage?:(data
- 基于uniapp使用websocket进行实时通讯
不爱说话郭德纲
前端javascript开发语言vue.js
前言最近在做一个赛事的需求,需要使用实时通讯实现房间内交换位置,转让房主,踢出房间等操作记录一下基于uniapp中websocket的封装和使用话不投机半句多(少bb),准备动手,准备动手ws方法封装1.类定义类名:WebsocketTask私有属性:#heartbeatInterval:心跳定时器。#callback:回调函数。#websocketStatus:WebSocket连接状态。#is
- Oracle RAC 三种心跳机制
数据库急诊日记
故障处理oracle数据库databaselinuxjavapythonc语言
在OracleRAC(RealApplicationClusters)中,心跳(Heartbeat)是集群节点间用于检测存活状态的核心机制,确保节点间的通信正常并避免脑裂(SplitBrain)问题。以下是RAC的三种关键心跳机制及其作用:1.网络心跳(NetworkHeartbeat)作用:通过私有网络互联(PrivateInterconnect)实时检测节点间的通信状态。工作原理:每个节点周期
- MySQL Heartbeat+drbd高可用
脚灬印
MySQLmysql
MySQLHeartbeat+drbd高可用环境--具体的配置信息如下所示:角色ip地址主机名字server-idprimary心跳及传输IP:192.168.0.51data-11管理及对外IP:10.0.0.51VIP:10.0.0.151standby心跳及传输IP:192.168.0.52data-21管理及对外IP:10.0.0.51VIP:10.0.0.152Heartbeat安装配置
- websocket 封装及使用
maoer9999
websocketvuewebsocketvue
1.websocket.js封装好了,直接在项目中引入使用即可classjtWebSocket{//构造函数constructor(){this.webSocket=null;//webSocket对象this.url=null;//webSocket连接的urlthis.lastHeartBeat=0;//上一次心跳时间this.connectTimer=null;//重连定时器this.isP
- 安装与部署openeuler 的HA
VX-IT BANG
服务器网络linux
实现原理LinuxHA(HighAvailability,高可用性)是指利用Linux操作系统构建的高可用集群解决方案,旨在确保关键业务服务在面临硬件故障、软件错误、网络中断等各种异常情况时,依然能够持续、稳定地运行,尽量减少服务中断时间,提高系统的可靠性和可用性。以下从几个方面详细介绍:关键组件和技术心跳监测(Heartbeat)这是LinuxHA系统中最基础也是最重要的组件之一。它通过在节点之
- Feign
Mr_蜗牛
SpringCloud
在上个例子中,我通过1、启动eureka2、注册服务3、调用服务做了一个简单的demo,但是在最后面,我是通过这样一段代码来调用服务的提供者的@GetMapping("/movie/{id}")publicUserfindById(@PathVariableLongid){//http://localhost:7900/simple///VIPvirtualIP//HAProxyHeartbeat
- WebSocket通信中心跳机制的作用
♚呜啦啦啦啦啦啦啦
websocket网络协议网络
心跳机制是WebSocket连接管理中的一个重要部分,用于确保连接的稳定性和可靠性。通过定期发送心跳消息并接收服务器的响应,可以有效地避免因网络问题导致的连接中断,并及时发现和处理连接异常情况。为什么有重连机制仍然需要心跳机制?虽然在连接中断后进行重连是一个重要的机制,但心跳(Heartbeat)机制依然有其不可替代的作用:1.及时发现连接问题心跳机制:通过定期发送心跳消息并接收确认响应,可以快速
- 线上Flink执行失败,Heartbeat Timeout异常分析
spring208208
大数据组件线上问题分析flink大数据
1.问题现象程序执行不稳当,时而正常,时而异常。对应的异常信息如下:执行过程中出现java.util.concurrent.TimeoutException:HeartbeatofTaskManagerwithidtimedoutjava.util.concurrent.TimeoutException:HeartbeatofTaskManagerwithidcontainer_e05_15788
- Kafka 消费端反复 Rebalance: `Attempt to heartbeat failed since group is rebalancing`
大秦王多鱼
Kafka修炼手册kafka分布式运维apache
文章目录Kafka消费端反复Rebalance:`Attempttoheartbeatfailedsincegroupisrebalancing`1.Rebalance过程概述2.错误原因分析2.1消费者组频繁加入或退出2.1.1消费者故障导致频繁重启2.1.2.消费者加入和退出导致的Rebalance2.1.3消费者心跳超时导致的Rebalance2.1.4如何解决频繁触发Rebalance的问
- mysql查看主从同步时间_MySql——主从同步延迟监控
李昭材
mysql查看主从同步时间
前言MySQL同步功能由3个线程(master上1个,slave上2个)来实现,简单的说就是:master发送日志一个,slave接收日志一个,slave运行日志一个。主从延迟判断的方法,通常有两种方法:Seconds_Behind_Master和pt-heartbeat1.Seconds_Behind_Master通过监控showslavestatus\G命令输出的Seconds_Behind_
- Etcd 配置详解
SkTj
配置标记成员标记—name—data-dir—wal-dir—snapshot-count—heartbeat-interval—election-timeout—listen-peer-urls—listen-client-urls—max-snapshots—max-wals—cors集群标记—initial-advertise-peer-urls—initial-cluster—initia
- 520表白html5爱心代码
youyouxiong
html5css前端
在HTML5中创建一个带有爱心动画的表白页面,可以通过结合CSS3动画和JavaScript来实现。以下是一个简单的示例代码,展示了如何制作一个带有动态爱心效果的表白页面:520表白@keyframesheartBeat{0%{transform:scale(1);}25%{transform:scale(1.1);}50%{transform:scale(1);}75%{transform:sc
- Spring Cloud微服务网关Zuul动态路由配置优化和手动触发路由刷新
NullzzZ
微服务SpringCloud系列文章springcloud微服务wpfjava后端springbootspring
一、前文必看SpringCloud微服务网关Zuul动态路由配置。在前文中留了两个小坑。在本文将怕它给填了,所以前一篇文章建议看一下。二、DynamicZuulRouteLocator小优化在前文中提到,HeartbeatEvent事件会频繁触发,每次都需要去查询数据库。而且ZuulRefreshListener监听的其余四个刷新事件也不会经常触发。所以这里就可以做一下小优化,因为系统上线稳定后,
- mavlink协议详解_MAVLink通讯协议在STM32上移植,并自定义协议
马卡斯·扬
mavlink协议详解
mavlink全称是(MicroAirVehicleMessageMarshallingLibrary),从名字可以看出,mavlink是主要面向飞控的一种开源通信协议。因此它默认定义了很多适用于飞控的信息格式,比如heartbeat(心跳信号,每隔一两秒主从通信一次,以验证通信是否正常)。首先要说明的是,mavlink作为一个非常可靠(至少两字节校验)、支持类型丰富(messageID、comp
- LVS/DR&LVS高可用集群
Hannah_zh
LinuxLVS集群keepalivedipvsadmVS/DR
一、基本知识HeartbeatHeartbeat项目是Linux-HA工程的一个组成部分,其与lvs在本质上无关。Heartbeat提供了2个核心的功能正是lvs所需要的,心跳监测部分和资源接管,心跳监测可以通过网络链路和串口进行,而且支持冗余链路,安装了Heartbeat的两台机器会通过心跳检测互相检测对方的状态,当检测到对方失效的时候会调用资源接管来做接管服务器,保证高可靠性。在一个高可靠的l
- nginx+keepalived实现高可用
四季三餐,有趣有盼
高可用nginx云计算运维
目录什么是keepalived?keepalived工作原理部署nginx+keepalived什么是keepalived?keepalived是集群管理中保证集群高可用的一个服务,类似于heartbeat,用来防止单节点故障。keepalived工作原理keepalived是以VRRP协议为基础实现的。VirtualRouteRedundancyProtocol,即虚拟路由冗余协议,它主要是实现
- 深入浅出理解kafka原理系列之:kafka消费者参数设置
最笨的羊羊
日常分享专栏Kafka深入理解kafka原理kafka消费者参数设置
深入浅出理解kafka原理系列之:kafka消费者参数设置1.max.poll.records2.max.poll.interval.ms3.enable.auto.commit4.heartbeat.interval.ms5.session.timeout.ms6.auto.offset.reset6.指定分区消费7.消息回溯消费8.指定offset消费9.指定时间点开始消费1.max.poll
- 矩阵求逆(JAVA)初等行变换
qiuwanchi
矩阵求逆(JAVA)
package gaodai.matrix;
import gaodai.determinant.DeterminantCalculation;
import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;
/**
* 矩阵求逆(初等行变换)
* @author 邱万迟
*
- JDK timer
antlove
javajdkschedulecodetimer
1.java.util.Timer.schedule(TimerTask task, long delay):多长时间(毫秒)后执行任务
2.java.util.Timer.schedule(TimerTask task, Date time):设定某个时间执行任务
3.java.util.Timer.schedule(TimerTask task, long delay,longperiod
- JVM调优总结 -Xms -Xmx -Xmn -Xss
coder_xpf
jvm应用服务器
堆大小设置JVM 中最大堆大小有三方面限制:相关操作系统的数据模型(32-bt还是64-bit)限制;系统的可用虚拟内存限制;系统的可用物理内存限制。32位系统下,一般限制在1.5G~2G;64为操作系统对内存无限制。我在Windows Server 2003 系统,3.5G物理内存,JDK5.0下测试,最大可设置为1478m。
典型设置:
java -Xmx
- JDBC连接数据库
Array_06
jdbc
package Util;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
public class JDBCUtil {
//完
- Unsupported major.minor version 51.0(jdk版本错误)
oloz
java
java.lang.UnsupportedClassVersionError: cn/support/cache/CacheType : Unsupported major.minor version 51.0 (unable to load class cn.support.cache.CacheType)
at org.apache.catalina.loader.WebappClassL
- 用多个线程处理1个List集合
362217990
多线程threadlist集合
昨天发了一个提问,启动5个线程将一个List中的内容,然后将5个线程的内容拼接起来,由于时间比较急迫,自己就写了一个Demo,希望对菜鸟有参考意义。。
import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.CountDownLatch;
public c
- JSP简单访问数据库
香水浓
sqlmysqljsp
学习使用javaBean,代码很烂,仅为留个脚印
public class DBHelper {
private String driverName;
private String url;
private String user;
private String password;
private Connection connection;
privat
- Flex4中使用组件添加柱状图、饼状图等图表
AdyZhang
Flex
1.添加一个最简单的柱状图
? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28
<?xml version=
"1.0"&n
- Android 5.0 - ProgressBar 进度条无法展示到按钮的前面
aijuans
android
在低于SDK < 21 的版本中,ProgressBar 可以展示到按钮前面,并且为之在按钮的中间,但是切换到android 5.0后进度条ProgressBar 展示顺序变化了,按钮再前面,ProgressBar 在后面了我的xml配置文件如下:
[html]
view plain
copy
<RelativeLa
- 查询汇总的sql
baalwolf
sql
select list.listname, list.createtime,listcount from dream_list as list , (select listid,count(listid) as listcount from dream_list_user group by listid order by count(
- Linux du命令和df命令区别
BigBird2012
linux
1,两者区别
du,disk usage,是通过搜索文件来计算每个文件的大小然后累加,du能看到的文件只是一些当前存在的,没有被删除的。他计算的大小就是当前他认为存在的所有文件大小的累加和。
- AngularJS中的$apply,用还是不用?
bijian1013
JavaScriptAngularJS$apply
在AngularJS开发中,何时应该调用$scope.$apply(),何时不应该调用。下面我们透彻地解释这个问题。
但是首先,让我们把$apply转换成一种简化的形式。
scope.$apply就像一个懒惰的工人。它需要按照命
- [Zookeeper学习笔记十]Zookeeper源代码分析之ClientCnxn数据序列化和反序列化
bit1129
zookeeper
ClientCnxn是Zookeeper客户端和Zookeeper服务器端进行通信和事件通知处理的主要类,它内部包含两个类,1. SendThread 2. EventThread, SendThread负责客户端和服务器端的数据通信,也包括事件信息的传输,EventThread主要在客户端回调注册的Watchers进行通知处理
ClientCnxn构造方法
&
- 【Java命令一】jmap
bit1129
Java命令
jmap命令的用法:
[hadoop@hadoop sbin]$ jmap
Usage:
jmap [option] <pid>
(to connect to running process)
jmap [option] <executable <core>
(to connect to a
- Apache 服务器安全防护及实战
ronin47
此文转自IBM.
Apache 服务简介
Web 服务器也称为 WWW 服务器或 HTTP 服务器 (HTTP Server),它是 Internet 上最常见也是使用最频繁的服务器之一,Web 服务器能够为用户提供网页浏览、论坛访问等等服务。
由于用户在通过 Web 浏览器访问信息资源的过程中,无须再关心一些技术性的细节,而且界面非常友好,因而 Web 在 Internet 上一推出就得到
- unity 3d实例化位置出现布置?
brotherlamp
unity教程unityunity资料unity视频unity自学
问:unity 3d实例化位置出现布置?
答:实例化的同时就可以指定被实例化的物体的位置,即 position
Instantiate (original : Object, position : Vector3, rotation : Quaternion) : Object
这样你不需要再用Transform.Position了,
如果你省略了第二个参数(
- 《重构,改善现有代码的设计》第八章 Duplicate Observed Data
bylijinnan
java重构
import java.awt.Color;
import java.awt.Container;
import java.awt.FlowLayout;
import java.awt.Label;
import java.awt.TextField;
import java.awt.event.FocusAdapter;
import java.awt.event.FocusE
- struts2更改struts.xml配置目录
chiangfai
struts.xml
struts2默认是读取classes目录下的配置文件,要更改配置文件目录,比如放在WEB-INF下,路径应该写成../struts.xml(非/WEB-INF/struts.xml)
web.xml文件修改如下:
<filter>
<filter-name>struts2</filter-name>
<filter-class&g
- redis做缓存时的一点优化
chenchao051
redishadooppipeline
最近集群上有个job,其中需要短时间内频繁访问缓存,大概7亿多次。我这边的缓存是使用redis来做的,问题就来了。
首先,redis中存的是普通kv,没有考虑使用hash等解结构,那么以为着这个job需要访问7亿多次redis,导致效率低,且出现很多redi
- mysql导出数据不输出标题行
daizj
mysql数据导出去掉第一行去掉标题
当想使用数据库中的某些数据,想将其导入到文件中,而想去掉第一行的标题是可以加上-N参数
如通过下面命令导出数据:
mysql -uuserName -ppasswd -hhost -Pport -Ddatabase -e " select * from tableName" > exportResult.txt
结果为:
studentid
- phpexcel导出excel表简单入门示例
dcj3sjt126com
PHPExcelphpexcel
先下载PHPEXCEL类文件,放在class目录下面,然后新建一个index.php文件,内容如下
<?php
error_reporting(E_ALL);
ini_set('display_errors', TRUE);
ini_set('display_startup_errors', TRUE);
if (PHP_SAPI == 'cli')
die('
- 爱情格言
dcj3sjt126com
格言
1) I love you not because of who you are, but because of who I am when I am with you. 我爱你,不是因为你是一个怎样的人,而是因为我喜欢与你在一起时的感觉。 2) No man or woman is worth your tears, and the one who is, won‘t
- 转 Activity 详解——Activity文档翻译
e200702084
androidUIsqlite配置管理网络应用
activity 展现在用户面前的经常是全屏窗口,你也可以将 activity 作为浮动窗口来使用(使用设置了 windowIsFloating 的主题),或者嵌入到其他的 activity (使用 ActivityGroup )中。 当用户离开 activity 时你可以在 onPause() 进行相应的操作 。更重要的是,用户做的任何改变都应该在该点上提交 ( 经常提交到 ContentPro
- win7安装MongoDB服务
geeksun
mongodb
1. 下载MongoDB的windows版本:mongodb-win32-x86_64-2008plus-ssl-3.0.4.zip,Linux版本也在这里下载,下载地址: http://www.mongodb.org/downloads
2. 解压MongoDB在D:\server\mongodb, 在D:\server\mongodb下创建d
- Javascript魔法方法:__defineGetter__,__defineSetter__
hongtoushizi
js
转载自: http://www.blackglory.me/javascript-magic-method-definegetter-definesetter/
在javascript的类中,可以用defineGetter和defineSetter_控制成员变量的Get和Set行为
例如,在一个图书类中,我们自动为Book加上书名符号:
function Book(name){
- 错误的日期格式可能导致走nginx proxy cache时不能进行304响应
jinnianshilongnian
cache
昨天在整合某些系统的nginx配置时,出现了当使用nginx cache时无法返回304响应的情况,出问题的响应头: Content-Type:text/html; charset=gb2312 Date:Mon, 05 Jan 2015 01:58:05 GMT Expires:Mon , 05 Jan 15 02:03:00 GMT Last-Modified:Mon, 05
- 数据源架构模式之行数据入口
home198979
PHP架构行数据入口
注:看不懂的请勿踩,此文章非针对java,java爱好者可直接略过。
一、概念
行数据入口(Row Data Gateway):充当数据源中单条记录入口的对象,每行一个实例。
二、简单实现行数据入口
为了方便理解,还是先简单实现:
<?php
/**
* 行数据入口类
*/
class OrderGateway {
/*定义元数
- Linux各个目录的作用及内容
pda158
linux脚本
1)根目录“/” 根目录位于目录结构的最顶层,用斜线(/)表示,类似于
Windows
操作系统的“C:\“,包含Fedora操作系统中所有的目录和文件。 2)/bin /bin 目录又称为二进制目录,包含了那些供系统管理员和普通用户使用的重要
linux命令的二进制映像。该目录存放的内容包括各种可执行文件,还有某些可执行文件的符号连接。常用的命令有:cp、d
- ubuntu12.04上编译openjdk7
ol_beta
HotSpotjvmjdkOpenJDK
获取源码
从openjdk代码仓库获取(比较慢)
安装mercurial Mercurial是一个版本管理工具。 sudo apt-get install mercurial
将以下内容添加到$HOME/.hgrc文件中,如果没有则自己创建一个: [extensions] forest=/home/lichengwu/hgforest-crew/forest.py fe
- 将数据库字段转换成设计文档所需的字段
vipbooks
设计模式工作正则表达式
哈哈,出差这么久终于回来了,回家的感觉真好!
PowerDesigner的物理数据库一出来,设计文档中要改的字段就多得不计其数,如果要把PowerDesigner中的字段一个个Copy到设计文档中,那将会是一件非常痛苦的事情。