深圳搬家搬厂网站建设公司
当前位置:网站首页 > 新闻动态 > 网络缓存服务器有哪些软件(REDIS缓存,持久化,高可用) 返回列表

网络缓存服务器有哪些软件(REDIS缓存,持久化,高可用)

发布时间:2023-12-05来源:网站建设公司


一,Redis作缓存服务器

redis作为缓存服务器是众多企业中的选择之一,虽然该技术很成熟但也是存在一定的问题。就是缓存带来的缓存穿透,缓存击穿,缓存失效问题,继而引用分布式锁。

网络缓存服务器有哪些软件(Redis缓存,持久化,高可用)

1.1,缓存穿透

在如今的项目中大多采用垂直的MVC架构,由service层去调用DAO层,然后DAO层再去查询数据库。而redis作为缓存服务器就是在service层去调用DAO层去查询时先去缓存服务器查询,如果存在则直接返回该数据,否则再去查询数据库。由此可知,这么做大量减少了对磁盘I/O的操作,减轻了数据库的压力。

现在我们假设一种情况,在数据库中存在有id为1到1000的数据。现在如果有人手动去模拟一个id为1001的请求,那么该数据在缓存服务器中是不存在的,因而便会去查询数据库。那么问题来了,如果是一个大量无效的请求去查询数据库。则势必会对数据库造成难以承受的压力,这种情况就是所谓的缓存穿透。

那如何解决呢?

1,将查询到的null值直接保存到缓存服务器中,但是这种做法并不推荐,因为如果是大量不同的请求id同样会去查询数据库。

2,接口的限流,降级与熔断

在项目中对于重要的接口一定要做限流,对于以上恶意攻击的请求除了要限流,还要做好降级准备,并且进行熔断,这种做法可以有效控制大量无效请求。

3,布隆过滤器

Bloomfilter就类似于一个hash set,用于快速判某个元素是否存在于集合中,其典型的应用场景就是快速判断一个key是否存在于某容器,不存在就直接返回。布隆过滤器的关键就在于hash算法和容器大小,该做法是多数企业所选择的。

1.2,缓存击穿

在高并发下,对某些 热点的值进行查询,但是这个时候缓存正好过期了,缓存没有命中,导致大量请求直接落到数据库上,此时这种大量的请求可能会是数据库崩盘。

解决方案:

1,将热点key设置成永不过期。

2,使用互斥锁。

以上两种情况均是属于缓存失效,但里面还有小小的细节。那就是存在多个缓存同时失效的问题,尤其在高并发时间段。为避免这种多个缓存失效的问题,我们在设置超时时间的时候,可以使用固定时间+随机时间。以最大限度避免当缓存失效时大量请求去查询数据库。

1.3,分布式锁

通常情况下分布式锁有三种实现方式,1. 数据库乐观锁;2. 基于ZooKeeper的分布式锁;3. 基于Redis的分布式锁;这里只记录基于redis的分布式锁。

作为分布式锁的要求:

  • 互斥性: 保证在分布式应用集群中,同一把锁在同一时间只能被一台机器上的一个线程执行。
  • 避免死锁:有一个客户端在持有锁的过程中崩溃而没有解锁,也能保证其他客户端能够加锁。

先参看如下代码:

public List<Goods> goodsManager() { System.out.println("调用过了业务层的goodsManager方法"); return goodsDao.queryAllPage(); // 1,先去查询缓存服务器 List<Goods> goodsList = (List<Goods>) redisTemplate.opsForValue().get("goods"); if(goodsList == null){ // 2,申请分布式锁 RedisConnection conn = redisTemplate.getConnectionFactory().getConnection(); if(conn.setNX("lock".getBytes(), "1".getBytes())){ // 3,给分布式锁设置一个超时时间 conn.expire("lock".getBytes(), 60); System.out.println("去数据库中查询所有的商品"); // 4,缓存中没有商品列表的数据 goodsList = goodsDao.queryAllPage(); // 5,将结果放入缓存中 redisTemplate.opsForValue().set("goods", goodsList); redisTemplate.expire("goods", 5, TimeUnit.MINUTES); // 6,释放分布式锁 conn.del("lock".getBytes()); } else { try { Thread.sleep(50); goodsManager(); } catch (InterruptedException e) { e.printStackTrace(); } } return goodsList; } else { //缓存服务器中有商品列表的数据 return goodsList; } } 

代码设计思路:

1,请求到来调用方法。

2,先去redis缓存中查询是否存在,如果没有则查询数据库。

3,使用原生的连接(setNX)获得分布式锁,然后设置超时时间。

设置超时时间的原因在于,如果线程获得锁之后不下心崩溃,为防止发生死锁因而设置超时时间。

4,查询数据库获得数据,并保存在数据库中。

5,释放锁。

1.4,雪崩效应

简单来说,缓存在同一时间内大量键(key)过期(失效),而新的缓存又没有即时的保存到服务器中,此时大量的请求瞬间都落在了数据库中导致连接异常。

解决方案:

1、可以使用分布式锁 ,单架构项目使用syn

2、永不过期

3、在设置缓存超时时间,固定时间+随机超时时间,防止多数缓存同时失效。

4、高可用,集群

1.5,redis缓存与springboot整合

在启动函数中先要开启缓存注解@Enablecaching

@Cacheable

被该注解标注的方法,会在执行前查询缓存服务器,如果缓存服务器有结果,则直接返回结果,当前方法就不会执行。如果没有结果,则在执行该方法的方法体,并且将该方法返回值放入缓存服务器中。

@CachePut

该注解和@Cacheable注解的功能差不多,唯一的区别在于不管缓存服务器有没有对应的值,都会去调用相应的方法用于添加和更新的方法。

@CacheEvict

删除指定的缓存,一般用于删除方法的使用 。

二,Redis持久化

### 2.1,redis提供两种持久化方式: 
  • RDB:它是备份当前瞬间Redis在内存中的数据结构(就是我们所说的快照)。
  • AOF:它的作用是当Redis执行写命令后,在一定的条件下将执行过的写命令依次保存在Redis的文件中,以后依次执行这些保存的命令就可回复Redis的数据。

2.2,RDB原理分析

RDB持久化有两种操作方式,手动操作进行持久化。

  • save:会阻塞当前Redis服务器,直到持久化完成,线上应该禁止使用。
  • bgsave:该触发方式会fork一个子进程,由子进程负责持久化过程,因此阻塞只会发生在fork子进程的时候。

bgsave和save最大的区别在于bgsave不会阻塞客户端的写操作,但是如果bgsave执行失败,Redis默认将停止接受接入操作,否则就没人会注意到灾难的发生,如果不希望这样做,可以将

stop-writes-on-bgsave-error yes设置为no

另一种为自动触发持久化,首先我们可以在配置文件中配置快照的规则。

save 900 1 当900秒以内执行1个写命令,使用快照备份

save 300 10 当300秒以内执行10个写命令,使用快照备份

save 60 10000 当60秒以内执行10000个写命令,使用快照备份

注意:redis执行备份命令时,将禁止写入命令

2.3,AOF原理分析

AOF的整个流程大体来看可以分为两步,一步是命令的实时写入,第二步是对aof文件的重写,重写是为了减少aof文件的大小。

AOF文件追加大致流程为:命令写入-->追加到aof_buf(缓冲区) -->同步到aof磁盘。为什么要先写入buf缓冲区在同步到磁盘呢?因为如果实时写入便会带来大量的磁盘I/O操作,会很大程度上降低系统的性能。

关于AOF持久化大概有以下几种配置。

  • appendonly no 是否启用AOF备份,默认为no,不启用,如果需要启用则改为yes。
  • appendfilename "appendonly.aof" 定义追加命令写入的文件为appendonly.aof
  • # appendfsync always
  • always表示每次执行redis命令都会同步保存到AOF文件中,性能会收影响,但是安全性很高。
  • appendfsync everysec
  • evarysec (默认)表示每一秒同步一次,性能会提升,但是安全性会下降,可能丢失1秒之内的命令。
  • #appendfsync no
  • no 表示不同步,需要手动执行同步命令,性能得到了保证,但是安全性太差。

2.4,Redis内存回收策略

在redis.conf中的配置项maxmemory-policy用于配置redis的内存回收策略,当内存达到最大值时所采取的内存处理方式。

redis提供六种内存淘汰策略

volatile-lru: allkeys-lru: volatile-random: allkeys-random: volatile-ttl: noeviction(默认): 

在内存回收机制中,LRU算法和TTl算法在redis中都不是精准计算,而是一个近似算法。redis默认有一个探测数量的配置maxmemory-samples 默认为3。

网络缓存服务器有哪些软件(Redis缓存,持久化,高可用)

三,Redis高可用

3.1,主从复制

在用户量非常庞大的时候,单台redis肯定是完全不够用的。因此更多的时候我们更希望可以读/写分离,读/写分离的前提就是读操作比写操作频繁的多,将数据放在多台服务器上那么久可以消除单台服务器的压力。

因此对于服务器的搭建如图:

网络缓存服务器有哪些软件(Redis缓存,持久化,高可用)

假设一台服务器负责写操作,其余三台为读操作,以此实现一个独写分离的缓存功能。但是很明显存在一种弊端,就是其余三台读取数据的服务器它们之间的数据是不能够进行同步的。这样便造成数据不一致的情况,此时就需要对它们之间进行一个数据上的互通。

简单介绍一下主从复制的概念,如上图 Master为主,负责写入数据的操作,其余 三台为从(Slave),负责读取数据操作。当有数据写入时,根据配置好的属性自动将更新的数据复制到其余三台服务器中,这样便实现了服务器之间的数据一致性。

网络缓存服务器有哪些软件(Redis缓存,持久化,高可用)

主从复制的大致流程:

1、保证主服务器(Master)的启动。

2、当从服务器启动时,发送SYNC命令给主服务器。主服务器接受到同步命令时,就是执行bgsave命令备份数据,但是主服务器并不会拒绝客户端的写操作,而是将来自客户端的写命令写入缓冲区。从服务器在未收到主服务器的备份快照文件之前,会根据配置决定使用现有数据响应客户端还是返回错误。

3、当bgsave命令被主服务器执行完后,开始向从服务器发送备份文件,这个时候从服务器就会丢弃现有的所有数据,开始载入发送过来的快照文件。

4、当主服务器发送完备份文件后,会将bgsave执行之后的缓存区内的写命令也发送给从服务器,从服务器完成备份文件解析后,就开始等待主服务器的后续命令。

5、同步完成以后,每次主服务器完成一次写入命令,都会同时往从服务器发送同步写入命令,主从同步就完成了。

从机配置:

slaveof server port 设置Master的ip和端口

masterauth root 设置Master的密码

到此为止,就完成了吗?

并不是,以上步骤只是完成了主从复制,并没有完成读写分离。并且,如果主(Master)服务器宕机,那整个缓存服务器就全部挂掉了。==而且作为从(Slave)服务器时不可以进行写的操作,==那又如何解决呢(哨兵模式)?

3.2,哨兵模式

1,什么时哨兵模式?

当Master宕机以后需要手动的把一台Slave切换为Master,这种方式需要人工干预,费时费力。因此哨兵模式可以帮助我们解决这个问题。

2,简述哨兵模式

  • 哨兵是一个独立的进程。
  • 哨兵会检测多个redis服务器,包括Master和Slave。通过发送命令,让redis服务器响应,检测其运行状态。
  • 当哨兵检测到master宕机,就会自动将slave切换成master,然后通过发布订阅模式通知其他slave修改配置文件,切换主机。
  • 为了实现哨兵的高可用,可以配置成多哨兵模式,即多个哨兵进程运行在不同的服务器上检测各个redis服务器,哨兵两两之间也会互相监控。
  • 多哨兵模式时,Master一旦宕机,哨兵1检测到这个结果,并不会马上进行故障切换,而仅仅是哨兵1主管的认为Master不可用。当其他哨兵也检测到Master不可用时,并且有一定的数量后,那么哨兵之间就会形成一次投票,投票的结果由一个哨兵发起,进行切换操作,切换完成后,就会通过发布订阅方式让各个哨兵把自己监控的服务器实现切换主机。

3,哨兵模式配置

3.1,#配置哨兵配置文件:

redis/src/sentinel.conf

3.2,#禁止保护模式

protected-mode no

3.3,#配置监听的主服务, 最后的2表示当2个或2个以上的哨兵认为主服务不可用才会进行故障切换

sentinel monitor 服务器名称(自定义) 主服务ip 端口 2

3.4,#定义服务密码

sentinel auth-pass 服务器名称(和上面相同) 密码

3.5,#启动哨兵模式;

./redis-sentinel sentinel.conf

4,其他相关配置

sentinel down-after-milliseconds : 指定哨兵在检测redis服务时,当redis服务在一个毫秒数内都无法回答时,单个哨兵认为的主观下线时间,默认为30秒。

sentinel failover-timeout: 指定故障切换运行的毫秒数,当超过这个毫秒数时,就认为切换故障失败,默认3分钟。

sentinel notification-script: 指定哨兵检测到redis实例异常时,调用的报警脚本。

3.3,分片集群

分片集群原理在于多个缓存服务器之间两两相互通信,每个复制集具有一个主实例和多个从实例。并且每个复制集朱保存一部分数据库中的键值对,解决了主从复制集中总数据存储量最小实例的限制,大大扩大了缓存服务器的大小。

其结构图如下:

网络缓存服务器有哪些软件(Redis缓存,持久化,高可用)

1,分片集群特点

1、Client与redis节点直接连接,不需要中间proxy层。

2、 redis-cluster把所有的物理节点映射到[0-16383]slot(插槽)上,cluster 负责维护。

3、所有的redis节点彼此互联(PING-PONG机制),内部使用gossip二进制协议优化传输数据。

4、 节点的失效检测是通过集群中超过半数的节点检测失效时才生效。

==问题:Redis 集群中内置了 16384 个哈希槽,那他是如何决定将key放入哪个插槽的?==

当Redis 集群中放置一个 key-value 时,redis 先对 key 使用 crc16 算法算出一个结果,然后把结果对 16384 求余数,这样每个 key 都会对应一个编号在 0-16383 之间的哈希槽,redis 会根据节点数量大致均等的将哈希槽映射到不同的节点。

2,集群搭建步骤

前置条件:

删除redis/src下的appendonly.aof,dump.rdb,nodes-6379.conf3个文件。

1、修改redis.conf,配置集群信息开启集群,

cluster-enabled yes 指定集群的配置文件,

cluster-config-file nodes- 端口.conf

2、用redis-trib.rb搭建集群因为redis-trib.rb是用Ruby实现的Redis集群管理工具,所以我们需要先安装ruby的环境.

2.1、安装ruby

yum -y install zlib ruby rubygems

2.2、安装rubygems的redis依赖

gem install -l redis-3.3.0.gem

3、安装好依赖的环境之后,我们就可以来使用脚本命令了

注意:此脚本文件在我们的解压缩目录src下。

执行命令:

./redis-trib.rb create --replicas 0 192.168.10.167:6379 192.168.10.167:6380 192.168.10.167:6381 开放16379 redis端口+1W--replicas 0:指定了从数据的数量为0。

4、查看集群状态

通过客户端输入以下命令:

cluster nodes:这个命令可以查看插槽的分配情况

整个Redis提供了16384个插槽,./redis-trib.rb 脚本实现了是将16384个插槽平均分配给了N个节点。

end:如果你觉得本文对你有帮助的话,记得关注点赞转发,你的支持就是我更新动力。

阅读过此文章的读者,还阅读过下面的文章

  • 深圳网站制作好后来年到期了该怎么办
    <p> 深圳网站制作好后来年到期了该怎么办,不管是个人还是公司,要想制作好一个网站真的不容易,不仅仅需要做网站前期的规划和策划工作,还需要对网站建设的栏目,内容进行填充和建设,面对这一堆的要求和东西,整体还是比较麻烦和费事的,所以,网站建设制作好之后,一定要注意来年的续费问题,好多公司不注意这个问题,造成了网站后期打不开了,不能正常方面了,出现了问题才想起来网站没有续费,接下来我们来看看深圳网络公司是如何建议的。 </p> <p> 1.域名到期的影响<br /> &nbsp;一般情况下,网站域名需要一年进行一次续费,也可以一次购买多年,如果域名到期没有及时续费,网站就会打不开,域名续费期一般是一个月,过了这个时间就会进入赎回期,这时候就不能续费了。<br /> &nbsp;2.服务器到期的影响<br /> &nbsp;服务器到期与域名一样,到期后网站同样不能打开,如果之前网站在做推广,会直接影响展现效果,长时间不续费的话,网站数据就会全部删除了,之前的努力就全白做了。<br /> &nbsp;3.网站维护服务到期<br /> &nbsp;有些网络公司服务商会有网站维护费用,一般都是一年为一个期限,如果到期后您没有及时维护,网站出现问题后就不会有人给您维护,就会造成影响。影响最大的就是网站展现的效果。<br /> </p>
  • 深圳做网站公司做网站时要明白这些
    <p> 深圳做网站公司做网站时要明白这些。其实做网站有的时候不仅仅是在做网站,更多的是在帮助其他公司在做网络宣传门户,站在这个角度上你就知道你所承担的责任了,作为现在公司网站建设不仅要符合时代潮流,更多的需要紧扣时代网页设计特色和要求,只有这样制作设计出来的网站才能更好的满足现在人们的使用要求和观念的,不管是在网站设计理念,网站布局规划,以及网站内容建设等等,这些方面都需要进口时代主题和要求的,接下来我们来看看深圳网站制作公司是如何做的,需要做好那些方面的要求和规范呢? </p> <p> 审美在变,网站设计要紧跟潮流<br /> 也许用户访问时,不会逐一阅读网站内容,但首先映入眼帘的一定是设计。也许网站在几年前设计制作的确实很漂亮,但是我们无法否认的事实是,用户对网站设计的审美一直在不断改变。这个比较容易对比,随便找一个行业,然后通过百度搜索到十家网站,分别对应年份和网站的网址,让一个不知情的人去逐一打开并评判感受。大体趋势是越是新近设计制作的网站,越容易赢得用户的接受承认。其实这就是用户的真实感受,每年快速改版重做对于很多公司来说有些压力,但是笔者认为一般而言网站2-3年是需要重新设计制作快速的。一个通过网站寻找供应商的用户,其浏览网站一般也就几十秒到几分钟时间,先进的网站设计效果是吸引其深入了解进而咨询的较好方法。<br /> 技术在变,网站制作要贴合需求<br /> 周围的一切都在发生着巨变,网站技术也是如此,此前被很多网站公司采用的ASP网站开发语言几乎已经没人使用,相对于传统的PC端网站,现在更多看重的是移动端,公司设计制作的网站现在多为自适应PC端、PAD端以及手持移动终端的响应式网站。谁也不知道网站技术会走向哪个方向,但是对于普通的企业而言,我们可以把握趋势,至少每隔两三年对网站重新快速设计制作。<br /> 企业在变,网站建设要适应发展<br /> 网站总是为企业服务的,换句话说就是网站的设计制作需要跟上企业的发展步伐。现在急剧变化的市场面前,如果想立于不败之地,企业的经营策略一定在不断调整优化。作为给企业发展提供服务的网站,其理应不断调整不断优化以适应公司需求。现在是互联网时代,用户了解公司更多的也是通过网络,网站不仅是营销的工具,更是企业品牌形象的展示窗口。由于人力成本的不断升高,而网站设计更多的需要技术人员手工完成,所以真正定制开发的网站都价格不菲。但是同样是网站建设公司网站改版也不一定就选择定制,如果有合适的模板网站,也是不做的选择。我们需要的是一个紧跟时代和用户需求的网站,而非一定采用哪种方式实现它。 </p>
  • 英文网站制作需要注意那些问题和事项
    英文网站制作需要注意那些问题和事项。英文网站制作还是跟中文网站制作有比较大的区别的,应为中文网站面对的客户群体是国内的用户,而国内的用户对网站的使用习惯,要求都是跟国外不一样的,从而在制作英文网站的时候,一定要注意,像这种英文网站制作还是需要从国外人使用网站的习惯,使用网站的一些喜好出发,只有这样制作出来的网站满足国外人的使用的,这是一个方面,另外一个方面就是国外网站面对的搜索引擎,也是不一样的,国外的搜索引擎跟国内有着比较大的区别的,搜索引擎也是制作英文网站必须要考虑的一个方面了,最后就是网站制作价格方面了,一般英文网站制作价格要比国内的网站制作价格高一些,这是一定的,毕竟国外网站制作的细节要求,以及针对搜索引擎优化方面还是有比较高的要求的,所以,这些都是工作量,也都是需要处理好这些方面的细节工作的。
  • 网站设计公司的发展趋势详解
    <p> 网站设计公司的发展趋势详解,目前网页设计公司慢慢的转型升级成为一种综合性的设计公司了,不仅仅是在网站设计了,如果单纯的依赖于网站设计,对于这样的公司来说现在还是很被动的,并且目前的网站制作价格已经白热化了,竞争也是很大的情况下,好多公司已经赚不到什么钱了,面对这样的市场形式,作为网站设计公司要不断的扩大和尝试新的方式和方法,实现公司业务的升级和转型,这也是摆在深圳<a href="http://www.szbc888.com" target="_blank"><strong>网站制作公司</strong></a>面对不可逾越的一个问题了,毕竟现在网站制作公司的活量不大,如果养一个专业的网页设计技术团队专门作网站,根本养活不了这样的公司的发展了,更多的还需要通过其他的渠道,其他的平台上获得更为有质量的客户,这也是当下网站制作公司不得不面对的一个话题了。 </p> <p> <img src="static/picture/20231030113846_47114.jpg" alt="" /> </p> <p> <a href="http://www.szbc888.com" target="_blank"><strong>网页设计公司</strong></a>业务范围扩大,于是着这个网站制作行业市场需求量在逐渐的缩小,并且凡是使用到网站的多半集中在一些公司,单位方面的需求了,对于一些个人对网站的需求还是很少的,除非一些专业化路线的个人才会这样做的,网站设计公司的转型升级,不仅提升的服务质量,更多的将服务方位不断的扩大,从而得到更好的市场群体,能够为更多的市场客户服务。 </p>
  • 网站制作低价格策略已经成为网站制作行业的杀手锏
    <p> 网站制作低价格策略已经成为网站制作行业的杀手锏,整个大环境不好的情况下,好多公司在制作网站的时候,已经在想尽办法降低网站制作的成本了,从当初的网站制作就直接去搜索引擎上搜索网站制作公司了,而如今制作网站已经发生变化了,从搜索引擎走向了淘宝,拼多多这些低价平台了,并且这些平台都是担保交易了,好多的需要<a href="http://www.szbc888.com" target="_blank"><strong>制作公司网站</strong></a>的商家慢慢转向这个方面来了,所以制作出来的网站不是模板的就是仿制的网站,价格的确很低,并且效率也是很高的,这也是聪明的用户慢慢的转型和变化了,如果这些模板网站放在搜索引擎来的客户的话,这些网站制作下来的费用基本上在好几千了,面对这样的市场转型和升级,这也让好多网站制作公司寻找不同的出路了。 </p> <p> <img src="static/picture/20231030113212_16069.jpg" alt="" /> </p> <p> <a href="http://www.szbc888.com" target="_blank"><strong>深圳网站制作</strong></a>的价格的确没有那么低,但是作为一些低价平台上的用户,他们为了争取到客户,低价引流,从而实现了低价格制作网站的形式,作为网站制作公司,你这样低价格去做的目的就只有一个,那就是辛苦转不到钱的,都是转一些辛苦钱而已,面对这样的市场形式和要求,作为网站制作公司一定要不断的提升网站制作的附加值,提升<a href="http://www.szbc888.com" target="_blank"><strong>网站制作</strong></a>的质量,让用户以质量取胜,不能专门走低价格战略,不然你的公司是发展不起来的,也作不大的,作为用户而已,你公司小还可以这样去做,如果公司发展到一定程度的去制作网站,这对于你的公司来说是灭顶之灾了,所以选择网站制作公司还是要从专业的角度出发去帮助客户解决实际的问题,从而实现网站制作公司的价值和效益。 </p>
  • 深圳网站定制开发全流程详解
    <p> 深圳网站定制开发全流程详解,作为网站定制开发公司接下来给大家普及一下网站定制究竟要经过那些过程呢,前期的网站沟通肯定是少不了的,除此之外,网站备案这块也是需要的,只要是正规的公司,正常的流程,网站备案也是需要做的,剩下的就是网站制作过程中的一些沟通了,接下来我们来看看<a href="http://www.szbc888.com" target="_blank"><strong>深圳网站制作</strong></a>公司的一个标准的流程。 </p> <p> 需求分析: 通过对客户业务的了解和与客户对流程的讨论对需求进行基本建模,最终形成需求规格说明书<br /> 总体设计: 通过分析需求信息,对系统的外部条件及内部业务需求进行抽象建模,最终形成概要设计说明文档<br /> 详细设计: 此部分在对需求和概要设计的基础上进行系统的详细设计(也包含部分代码说明)<br /> 开发编程: 对系统进行代码编写<br /> 测试分析与系统整合: 对所有功能模块进行模拟数据测试及其它相关性测试并整合所有模块功能<br /> 现场支持: 系统上线试运行进行现场问题记录、解答<br /> 系统运行支持: 系统正式推产后,对系统进行必要的维护和BUG修改<br /> </p>

Copyright © 2015 深圳市鑫惠广网络科技有限公司 粤ICP备2023111395号