- 高可用Keepalived在Linux中的应用
「已注销」
linux运维服务器高可用集群keepalivedcentos
目录一、高可用1.高可用介绍(1)普通理解(2)专业理解2.高可用目的3.高可用实现1.介绍2.特点三、Keepalived1.介绍2.Keepalived核心组件(1)VRRPstack(2)NetLink接口(3)IPVSWrapper(4)checkers(5)systemcall(6)SMTP(7)watchDog3.控制组件4.内存管理四、Keepalived核心概念1.虚拟路由器2.m
- keepalived应用
小卓笔记
服务器linux数据库
Keepalived是一个基于VRRP(虚拟路由冗余协议)实现的高可用解决方案,常用于构建高可用性的服务器集群,特别是在负载均衡场景中,可确保服务的不间断运行。以下为你详细介绍它:0主要功能高可用性:借助VRRP协议,Keepalived能在多台服务器间自动切换,当主服务器出现故障时,备用服务器可迅速接替工作,保障服务的持续可用。负载均衡:Keepalived可与LVS(Linux虚拟服务器)集成
- Linux企业实战-----LVS+keepalived负载均衡集群
Yang5208
linux负载均衡运维
用LVS实现负载均衡实现步骤:#若在虚拟环境中需执行此步骤创建两个新的虚拟机,VMWARE可忽略此步骤真实主机:cd/var/lib/libvirt/images/lsqemu-imgcreate-fqcow2-brhel7.6.qcow2server3qemu-imgcreate-fqcow2-brhel7.6.qcow2server4server1:pcsclusterdisable--all
- ## centos7搭建nfs高可用共享存储
weixin_45674361
高可用部署linux服务器centosnfs运维
centos7搭建nfs双机热备的高可用共享存储本文通过使用keepalived+nfs+rsync,解决了主从服务器双向同步和客户端挂载失效的问题,实现了nfs文件系统双机热备。名称IP地址客户端192.168.1.1服务端服务器1192.168.1.100服务端服务器2192.168.1.200实施步骤keepalived部署在192.168.1.100和192.168.1.200上执行安装依
- Nginx、LVS、HAProxy 的区别和优缺点
青年夏日科技
nginx运维
Nginx、LVS、HAProxy是目前使用最广泛的三种负载均衡软件,本人都在多个项目中实施过,通常会结合Keepalive做健康检查,实现故障转移的高可用功能。1)在四层(tcp)实现负载均衡的软件:lvs------>重量级nginx------>轻量级,带缓存功能,正则表达式较灵活haproxy------>模拟四层转发,较灵活2)在七层(http)实现反向代理的软件:haproxy----
- LVS、Haproxy、Nginx区别
SHISHIZHIZHI
nginx负载均衡服务器
LVS、Haproxy、Nginx区别一、Haproxy调度算法1.常见的web集群调度器2.Haproxy应用分析3.Haproxy调度算法原理4.Haproxy的主要特性5.Haproxy的优点6、LVS.Haproxy、Nginx区别二、Haproxy优化三、Haproxy日志1.修改主配置文件2.修改rsyslog配置一、Haproxy调度算法1.常见的web集群调度器目前常见的web集群
- lvs、nginx、haproxy区别和使用场景?
企鹅侠客
linux聊聊运维lvsnginx运维
0.运维干货分享软考系统架构设计师三科备考经验附学习资料信息安全管理体系(ISMS)制度模板分享免费文档翻译工具(支持word、pdf、ppt、excel)PuTTY中文版安装包MobaXterm中文版安装包pinginfoview网络诊断工具中文版LVS(LinuxVirtualServer)、Nginx和HAProxy都是常见的负载均衡工具,它们在不同的场景中各有优势。以下是它们的区别、特点及
- 【k8s集群部署篇】在openEuler环境下部署多master高可用kubernetes集群详细教程(V1.30版本)
江湖有缘
kubernetes容器云原生
【k8s集群部署篇】在openEuler环境下部署多master高可用kubernetes集群详细教程(V1.30版本)一、相关名词介绍1.1k8s简介1.2Keepalived简介1.3HAProxy简介二、本次实践介绍2.1环境规划介绍2.2本次实践简介三、所有节点基础环境配置3.1主机配置工作3.2关闭防火墙和selinux3.3关闭swap3.4清空iptables3.5配置时间同步3.6
- HAproxy+keepalived实现高可用
热心市民运维小孙
linux运维运维linux负载均衡
HAproxy+keepalived实现高可用实际环境中,单台负载均衡可能会因为流量太大而down掉,因此通过keepalived来实现容错高可用这个对与学网工的好理解,keepalived本身就是基于vrrp协议(虚拟路由冗余协议)里面的,通过VIP(虚拟IP)来实现容错,还有健康检查机制,主备切换通过优先级来判断。Keepalived高可用服务的故障切换转移是通过VRRP机制来实现的。在Kee
- sysbench手动测试OceanBase v4.2.4集群
king_harry
oceanbasesysbench数据库
环境:1、ocp(sysbench节点)192.192.103.1282、ob集群1-1-1observer192.192.103.125、192.192.103.126、192.192.103.127,primary_zone:randomhaproxy192.192.103.125、192.192.103.126、192.192.103.127一、安装sysbench(128)源码安装:JDK
- Linux之系统之配置HAProxy负载均衡服务器
江湖有缘
Linux技术学习服务器linux负载均衡
Linux之系统之配置HAProxy负载均衡服务器前言一、HAProxy介绍1.1HAProxy简介1.2主要特点1.3使用场景二、本次实践介绍2.1本次实践简介2.2本次实践环境规划三、部署两台web服务器3.1运行两个Docker容器3.2编辑测试文件3.3访问测试四、安装HAProxy4.1更新系统软件源4.2安装HAProxy4.3验证安装五、配置HAProxy5.2备份默认配置文件5.2
- KEEPALIVED高可用
Albert_OS
网络服务器运维
KEEPALIVED简介Keepalived软件起初是专为LVS负载均衡软件设计的,用来管理并监控LVS集群系统中各个服务节点的状态,后来又加入了可以实现高可用的VRRP功能。因此,Keepalived除了能够管理LVS软件外,还可以作为其他服务(例如:Nginx、Haproxy、MySQL等)的高可用解决方案软件。Keepalived软件主要是通过VRRP协议实现高可用功能的。VRRP是Virt
- nginx+keepalived实现高可用负载均衡
Spike()
nginx负载均衡
本文介绍了nginx反向代理多虚拟主机节点服务器配合keepalived实现高可用和负载均衡,keepalived除了能够管理LVS软件外,还可以作为其他服务的高可用解决方案软件。采用nginx+keepalived,它是一个高性能的服务器高可用或者热备解决方案,Keepalived主要来防止服务器单点故障的发生问题,可以通过其与Nginx的配合实现Web服务器端的高可用。使用keepalived
- 使用haproxy实现MySQL服务器负载均衡
obboda
mysql服务器负载均衡
一、环境准备主机名IP地址备注openEuler-1192.168.121.11mysql-server-1openEuler-2192.168.121.12mysql-server-2openEuler-3192.168.121.13clientRocky-1192.168.121.51haproxy二、mysql-server配置[root@openEuler-1~]#yuminstall-y
- LVS+Keepalived 高可用群集实例
ynyysn
nginx前端运维
文章目录一、Keepalived工具介绍二、Keepalived实现原理三、Keepalived配置文件四、LVS+Keepalived高可用群集的搭建4.1配置负载调度器(主:192.168.24.10)4.2配置负载调度器(备:192.168.24.20)4.3配置节点服务器web14.4配置节点服务器web2总结一、Keepalived工具介绍专为LVS和HA设计的一款健康检查工具支持故障自
- LVS+Keepalived高可用群集配置案例
IT_张三
运维lvs服务器运维
以下是一个LVS+Keepalived高可用群集配置案例:1、环境准备LVS主调度器(lvs1):IP地址为192.168.8.101,心跳IP为192.168.4.101LVS备调度器(lvs2):IP地址为192.168.8.102,心跳IP为192.168.4.102虚拟IP(vip):192.168.8.100Web服务器1(nginx1):IP地址为192.168.8.103Web服务器
- 高并发问题解决方案
负载均衡缓存异步处理限流微服务
高并发问题是指系统需要处理大量用户请求或大量并发操作时所面临的挑战,通常表现为请求量大、处理时间长、响应速度慢、资源耗尽等问题。为了应对高并发场景,系统需要设计成能够高效地处理并发请求,并确保系统的稳定性和可扩展性。以下是一些常见的解决高并发问题的方法和技术:1.负载均衡目的:分担单个服务器的压力,提高系统处理能力。实现方式:应用层负载均衡:使用负载均衡器(如Nginx、HAProxy、Traef
- dockerfile构建haproxy镜像
linlusama
dockerbashlinuxdocker
dockerfile构建haproxy镜像结构[root@dockerhaproxy]#tree.├──dockerfile├──entrypoint.sh└──file├──entrypoint.sh├──haproxy-2.4.0.tar.gz└──install.sh//创建dockerfile存放目录[root@docker~]#mkdir-p/haproxy/file[root@dock
- Dockerfile部署haproxy
Op_Wa
dockerlinux运维服务器dockerhaproxy
文章目录Dockerfile部署haproxydockerfile网站服务器测试功能Dockerfile部署haproxydockerfile//目录结构[root@192~]#treehaproxy/haproxy/├──Dockerfile├──files│├──haproxy-2.4.0.tar.gz│└──install.sh└──start.sh//dockerfile[root@192
- RabbitMQ集群搭建:使用HAProxy和Keepalived实现RabbitMQ的高可用负载均衡
EvktJava
rabbitmq负载均衡ruby
在本文中,我们将探讨如何使用HAProxy和Keepalived来搭建RabbitMQ的高可用负载均衡集群。我们还将介绍如何将SpringBoot与RabbitMQ集成,以便在应用程序中使用消息队列。搭建RabbitMQ集群首先,我们需要搭建一个RabbitMQ集群。在集群中,我们将有多个节点来处理消息队列的请求。每个节点都是独立的,但它们之间会相互通信以保持数据的同步。为了简化安装过程,我们将使
- HAProxy 1.8.13 编译安装
清笙漓江南
LinuxMircSystemctlhaproxy编译安装haproxysocket
HAProxy编译安装首先上官网获取haproxy的tar包解压至当前目录haproxy的配置文件中要使用到haproxy用户所以我们先创建该用户useradd-r-s/sbin/nologinhaproxytarxfhaproxy-1.8.13.tar.gzcdhaproxy-1.8.13/vimREADME文档其中我们可以查看到关于怎么样安装我们使用其中的一项,包括了pcre和ssl以及zli
- haproxy编译安装
qiqi妈
服务器网络linux
1.下载安装包2.将安装包上传至本地目录3.解压tarxvfhaproxy-1.5.19.tar.gz4.创建haproxy安装目录mkdir/usr/local/haproxy5.编译并安装haproxycd/home/haproxy-1.5.19/makeARCH=x86_64TARGET=linux2628USE_PCRE=1USE_OPENSSL=1USE_ZLIB=1USE_SYSTEM
- AWS Service Catalog Terraform 参考架构安装与使用指南
邓旭诚Kit
AWSServiceCatalogTerraform参考架构安装与使用指南aws-service-catalog-terraform-reference-architectureApplyTerraformconfigurationsusingCloudFormationthroughaproxylambda项目地址:https://gitcode.com/gh_mirrors/aw/aws-se
- AWS Service Catalog Terraform 参考架构常见问题解决方案
陆骊咪Durwin
AWSServiceCatalogTerraform参考架构常见问题解决方案aws-service-catalog-terraform-reference-architectureApplyTerraformconfigurationsusingCloudFormationthroughaproxylambda项目地址:https://gitcode.com/gh_mirrors/aw/aws-s
- Feign
Mr_蜗牛
SpringCloud
在上个例子中,我通过1、启动eureka2、注册服务3、调用服务做了一个简单的demo,但是在最后面,我是通过这样一段代码来调用服务的提供者的@GetMapping("/movie/{id}")publicUserfindById(@PathVariableLongid){//http://localhost:7900/simple///VIPvirtualIP//HAProxyHeartbeat
- openEuler系统之使用Keepalived+Nginx部署高可用Web集群
江湖有缘
Linux技术学习nginx前端keepalivedwebopneEuler
Linux系统之使用Keepalived+Nginx部署高可用Web集群一、本次实践介绍1.1本次实践简介1.2本次实践环境规划二、keepalived介绍2.1keepalived简介2.2keepalived主要特点和功能2.3使用场景三、Keepalived和Nginx介绍3.1Nginx简介3.2Nginx特点四、master节点安装nginx4.1安装nginx软件4.2编辑index.
- keepalived+mysql主从自动切换_使用keepalived实现对mysql主从复制的主备自动切换
PTE柒加
,通过keepalived自带的服务监控功能来实现MySQL故障时自动切换。实验环境中用两台主机搭建了一个mysql主从复制的环境,两台机器分别安装了keepalived,用一个虚IP实现mysql服务器的主备自动切换功能.模拟环境:VIP:192.168.1.197:虚拟IP地址Master:192.168.1.198:主数据库IP地址Slave:192.168.1.199:从数据库IP地址备注
- keepalived+timescaladb主备切换高可用方案
handsomestWei
数据库keepalivedtimescaladbpostgresql数据库高可用
keepalived+timescaladb主备切换高可用方案环境和组件依赖ubuntu22.04,docker引擎keepalivedv2.2.4timescaledbdocker镜像wjy2020/timescaledb-repmgr:pg14.15-ts2.17.2,镜像使用参考方案思路在双机分别部署这两个组件,keepalived定时检测timescaladb数据库的主备状态,当数据库状态
- LVS + KeepAlived 配置HA集群的步骤
千羽星弦
lvs服务器运维
LVS+KeepAlived配置HA集群的步骤(一)集群准备准备vmvarelinux虚拟主机4台,假设对外提供的VIP是192.168.174.110主机IP备注LVS1192.168.174.101提供4层代理-主机LVS2192.168.174.102提供4层代理-备用Apache1192.168.174.201真实服务器1Apache2192.168.174.202真实服务器2此处采用LV
- Linux防护与群集第七到九章
琴剑诗酒
linux
一、keepalive作用1.支持故障自动切换2.支持健康检查3.专为lvs和ha设计的健康检查工具二.vrrp:虚拟路由冗余协议1.hsrp:cisco私有2.vrrp:公有工作在网路层三、keepalived配置1.主从:除router_id、state、priority其余都一样2.主:master备用:backuppost与get区别get:1.内容直接附着在url中2.适合传输表单内容少
- Java实现的简单双向Map,支持重复Value
superlxw1234
java双向map
关键字:Java双向Map、DualHashBidiMap
有个需求,需要根据即时修改Map结构中的Value值,比如,将Map中所有value=V1的记录改成value=V2,key保持不变。
数据量比较大,遍历Map性能太差,这就需要根据Value先找到Key,然后去修改。
即:既要根据Key找Value,又要根据Value
- PL/SQL触发器基础及例子
百合不是茶
oracle数据库触发器PL/SQL编程
触发器的简介;
触发器的定义就是说某个条件成立的时候,触发器里面所定义的语句就会被自动的执行。因此触发器不需要人为的去调用,也不能调用。触发器和过程函数类似 过程函数必须要调用,
一个表中最多只能有12个触发器类型的,触发器和过程函数相似 触发器不需要调用直接执行,
触发时间:指明触发器何时执行,该值可取:
before:表示在数据库动作之前触发
- [时空与探索]穿越时空的一些问题
comsci
问题
我们还没有进行过任何数学形式上的证明,仅仅是一个猜想.....
这个猜想就是; 任何有质量的物体(哪怕只有一微克)都不可能穿越时空,该物体强行穿越时空的时候,物体的质量会与时空粒子产生反应,物体会变成暗物质,也就是说,任何物体穿越时空会变成暗物质..(暗物质就我的理
- easy ui datagrid上移下移一行
商人shang
js上移下移easyuidatagrid
/**
* 向上移动一行
*
* @param dg
* @param row
*/
function moveupRow(dg, row) {
var datagrid = $(dg);
var index = datagrid.datagrid("getRowIndex", row);
if (isFirstRow(dg, row)) {
- Java反射
oloz
反射
本人菜鸟,今天恰好有时间,写写博客,总结复习一下java反射方面的知识,欢迎大家探讨交流学习指教
首先看看java中的Class
package demo;
public class ClassTest {
/*先了解java中的Class*/
public static void main(String[] args) {
//任何一个类都
- springMVC 使用JSR-303 Validation验证
杨白白
springmvc
JSR-303是一个数据验证的规范,但是spring并没有对其进行实现,Hibernate Validator是实现了这一规范的,通过此这个实现来讲SpringMVC对JSR-303的支持。
JSR-303的校验是基于注解的,首先要把这些注解标记在需要验证的实体类的属性上或是其对应的get方法上。
登录需要验证类
public class Login {
@NotEmpty
- log4j
香水浓
log4j
log4j.rootCategory=DEBUG, STDOUT, DAILYFILE, HTML, DATABASE
#log4j.rootCategory=DEBUG, STDOUT, DAILYFILE, ROLLINGFILE, HTML
#console
log4j.appender.STDOUT=org.apache.log4j.ConsoleAppender
log4
- 使用ajax和history.pushState无刷新改变页面URL
agevs
jquery框架Ajaxhtml5chrome
表现
如果你使用chrome或者firefox等浏览器访问本博客、github.com、plus.google.com等网站时,细心的你会发现页面之间的点击是通过ajax异步请求的,同时页面的URL发生了了改变。并且能够很好的支持浏览器前进和后退。
是什么有这么强大的功能呢?
HTML5里引用了新的API,history.pushState和history.replaceState,就是通过
- centos中文乱码
AILIKES
centosOSssh
一、CentOS系统访问 g.cn ,发现中文乱码。
于是用以前的方式:yum -y install fonts-chinese
CentOS系统安装后,还是不能显示中文字体。我使用 gedit 编辑源码,其中文注释也为乱码。
后来,终于找到以下方法可以解决,需要两个中文支持的包:
fonts-chinese-3.02-12.
- 触发器
baalwolf
触发器
触发器(trigger):监视某种情况,并触发某种操作。
触发器创建语法四要素:1.监视地点(table) 2.监视事件(insert/update/delete) 3.触发时间(after/before) 4.触发事件(insert/update/delete)
语法:
create trigger triggerName
after/before 
- JS正则表达式的i m g
bijian1013
JavaScript正则表达式
g:表示全局(global)模式,即模式将被应用于所有字符串,而非在发现第一个匹配项时立即停止。 i:表示不区分大小写(case-insensitive)模式,即在确定匹配项时忽略模式与字符串的大小写。 m:表示
- HTML5模式和Hashbang模式
bijian1013
JavaScriptAngularJSHashbang模式HTML5模式
我们可以用$locationProvider来配置$location服务(可以采用注入的方式,就像AngularJS中其他所有东西一样)。这里provider的两个参数很有意思,介绍如下。
html5Mode
一个布尔值,标识$location服务是否运行在HTML5模式下。
ha
- [Maven学习笔记六]Maven生命周期
bit1129
maven
从mvn test的输出开始说起
当我们在user-core中执行mvn test时,执行的输出如下:
/software/devsoftware/jdk1.7.0_55/bin/java -Dmaven.home=/software/devsoftware/apache-maven-3.2.1 -Dclassworlds.conf=/software/devs
- 【Hadoop七】基于Yarn的Hadoop Map Reduce容错
bit1129
hadoop
运行于Yarn的Map Reduce作业,可能发生失败的点包括
Task Failure
Application Master Failure
Node Manager Failure
Resource Manager Failure
1. Task Failure
任务执行过程中产生的异常和JVM的意外终止会汇报给Application Master。僵死的任务也会被A
- 记一次数据推送的异常解决端口解决
ronin47
记一次数据推送的异常解决
需求:从db获取数据然后推送到B
程序开发完成,上jboss,刚开始报了很多错,逐一解决,可最后显示连接不到数据库。机房的同事说可以ping 通。
自已画了个图,逐一排除,把linux 防火墙 和 setenforce 设置最低。
service iptables stop
- 巧用视错觉-UI更有趣
brotherlamp
UIui视频ui教程ui自学ui资料
我们每个人在生活中都曾感受过视错觉(optical illusion)的魅力。
视错觉现象是双眼跟我们开的一个玩笑,而我们往往还心甘情愿地接受我们看到的假象。其实不止如此,视觉错现象的背后还有一个重要的科学原理——格式塔原理。
格式塔原理解释了人们如何以视觉方式感觉物体,以及图像的结构,视角,大小等要素是如何影响我们的视觉的。
在下面这篇文章中,我们首先会简单介绍一下格式塔原理中的基本概念,
- 线段树-poj1177-N个矩形求边长(离散化+扫描线)
bylijinnan
数据结构算法线段树
package com.ljn.base;
import java.util.Arrays;
import java.util.Comparator;
import java.util.Set;
import java.util.TreeSet;
/**
* POJ 1177 (线段树+离散化+扫描线),题目链接为http://poj.org/problem?id=1177
- HTTP协议详解
chicony
http协议
引言
- Scala设计模式
chenchao051
设计模式scala
Scala设计模式
我的话: 在国外网站上看到一篇文章,里面详细描述了很多设计模式,并且用Java及Scala两种语言描述,清晰的让我们看到各种常规的设计模式,在Scala中是如何在语言特性层面直接支持的。基于文章很nice,我利用今天的空闲时间将其翻译,希望大家能一起学习,讨论。翻译
- 安装mysql
daizj
mysql安装
安装mysql
(1)删除linux上已经安装的mysql相关库信息。rpm -e xxxxxxx --nodeps (强制删除)
执行命令rpm -qa |grep mysql 检查是否删除干净
(2)执行命令 rpm -i MySQL-server-5.5.31-2.el
- HTTP状态码大全
dcj3sjt126com
http状态码
完整的 HTTP 1.1规范说明书来自于RFC 2616,你可以在http://www.talentdigger.cn/home/link.php?url=d3d3LnJmYy1lZGl0b3Iub3JnLw%3D%3D在线查阅。HTTP 1.1的状态码被标记为新特性,因为许多浏览器只支持 HTTP 1.0。你应只把状态码发送给支持 HTTP 1.1的客户端,支持协议版本可以通过调用request
- asihttprequest上传图片
dcj3sjt126com
ASIHTTPRequest
NSURL *url =@"yourURL";
ASIFormDataRequest*currentRequest =[ASIFormDataRequest requestWithURL:url];
[currentRequest setPostFormat:ASIMultipartFormDataPostFormat];[currentRequest se
- C语言中,关键字static的作用
e200702084
C++cC#
在C语言中,关键字static有三个明显的作用:
1)在函数体,局部的static变量。生存期为程序的整个生命周期,(它存活多长时间);作用域却在函数体内(它在什么地方能被访问(空间))。
一个被声明为静态的变量在这一函数被调用过程中维持其值不变。因为它分配在静态存储区,函数调用结束后并不释放单元,但是在其它的作用域的无法访问。当再次调用这个函数时,这个局部的静态变量还存活,而且用在它的访
- win7/8使用curl
geeksun
win7
1. WIN7/8下要使用curl,需要下载curl-7.20.0-win64-ssl-sspi.zip和Win64OpenSSL_Light-1_0_2d.exe。 下载地址:
http://curl.haxx.se/download.html 请选择不带SSL的版本,否则还需要安装SSL的支持包 2. 可以给Windows增加c
- Creating a Shared Repository; Users Sharing The Repository
hongtoushizi
git
转载自:
http://www.gitguys.com/topics/creating-a-shared-repository-users-sharing-the-repository/ Commands discussed in this section:
git init –bare
git clone
git remote
git pull
git p
- Java实现字符串反转的8种或9种方法
Josh_Persistence
异或反转递归反转二分交换反转java字符串反转栈反转
注:对于第7种使用异或的方式来实现字符串的反转,如果不太看得明白的,可以参照另一篇博客:
http://josh-persistence.iteye.com/blog/2205768
/**
*
*/
package com.wsheng.aggregator.algorithm.string;
import java.util.Stack;
/**
- 代码实现任意容量倒水问题
home198979
PHP算法倒水
形象化设计模式实战 HELLO!架构 redis命令源码解析
倒水问题:有两个杯子,一个A升,一个B升,水有无限多,现要求利用这两杯子装C
- Druid datasource
zhb8015
druid
推荐大家使用数据库连接池 DruidDataSource. http://code.alibabatech.com/wiki/display/Druid/DruidDataSource DruidDataSource经过阿里巴巴数百个应用一年多生产环境运行验证,稳定可靠。 它最重要的特点是:监控、扩展和性能。 下载和Maven配置看这里: http
- 两种启动监听器ApplicationListener和ServletContextListener
spjich
javaspring框架
引言:有时候需要在项目初始化的时候进行一系列工作,比如初始化一个线程池,初始化配置文件,初始化缓存等等,这时候就需要用到启动监听器,下面分别介绍一下两种常用的项目启动监听器
ServletContextListener
特点: 依赖于sevlet容器,需要配置web.xml
使用方法:
public class StartListener implements
- JavaScript Rounding Methods of the Math object
何不笑
JavaScriptMath
The next group of methods has to do with rounding decimal values into integers. Three methods — Math.ceil(), Math.floor(), and Math.round() — handle rounding in differen