什么是JavaScript?
JavaScrjpt是由Netscape公司开发的一种脚本语言(scrptingIanguage)。在HTML基础上,使用Javascript可以开发交互式Web网页.Javascript的使用使得网页和用户之间多了一种实时性的、动态的、交互性的关系,使网页包含更多活跃的元素和更加动态的内容.运行用Javascript编写的程序需要支持Javascript语言的浏览器。
Javascr短小精悍,又是在客户机上执行的,大大提高了网页的浏览束度和交互能力.同时它又是专门为制作Web网页而量身定做的一种简单的编程语言。
Javascript是一种脚本语言,它采取小程序段的方式实现编程,像其他脚本语言一样,Javascript同样也是提供了一个简易的开发过程;它的基本结构形式与C、C++不同,不像这些语言一样,需要先编译,而是在
程序运行过程中被逐行地被解释.它与HTML表示结合在一起。
JavaScript特性
基于对象、跨平台
动态性
javascript是动态的可以直接对用户操作做出响应,无需经过Web服务器程序,以某事件作为驱动,如用户单击按钮提交、滚动鼠标等
安全性
即不可以访问本地文件、服务器文件、删除等操作,仅仅实现网页之间的交互,功能专一。
JavaScript架构
<script language="javascript" type="text/javascript"> //添加javascript代码 </script>
数据类型
1.基础数据类型
数值型、字符串型、逻辑型、undefined、null
2.复合数据类型
对象、数组、函数
由于JavaScript是一种无类型语言,所以,数组元素可以是任意的数据类型,同一数组的不同元素也可以具有不同的类型,数组元素也可以是其它数组,可以创建多维数组
数组声明如下:
/************************** *声明数组的三种方式 **************************/ //声明一个无类型数组 var strArray=new Array(); //声明一个长度为5的数组 var strArray=new Array(5); //声明一个函数5个指定元素的数组 var strArray=new Array(1,2,3,4,5); //Array对象的length属性用于说明数组包含的元素个数 var intNum=strArray.length;
事件处理机制
单击事件按钮例子:当单击事件触发时,弹出提示框,表示单击事件触发。
实现代码:
<script language="javascript" type="text/javascript"> //对单击事件作出响应 function Click() { alert("单击事件触发!"); } </script> <body>//给单击按钮添加事件 Onclick="javascript:Click()"事件 <input name="单击" type="button" align="middle" value="单击按钮" onclick="javascript:Click()" /> </body>
Javascript是一种松散类型、动态类型语言,声明变量时无需指定数据类型,从而更灵活、简单。
运算符、比较运算符、逻辑符号、三大流程控制语句、VB/C/C++等语言类型,我们都很熟悉
常见错误
1.区分大小写
如函数 function number(){} 与 function Number() {} 是两个不同的函数。
2.单引号、双引号
JS本身并没有规定一定使用双引号或单引号,但为了代码易读我们再JS代码中使用单引号而在HTML中使用双引号。例如
<script language="javascript" type="text/javascript"> //单双引号分开,使代码容易理解 var temp='<h2 class=“a”> A list </h2> </script>
4.不支持重载,会将原有函数覆盖掉
5.换行符
<script language="javascript" type="text/javascript"> //"\"为换行符 var temp='<h2 class=“a”> A list </h2> \ <ol>\ <ol>\ </script>
JavaScript应用的很广,也很多,是一种目前流行的脚本语言。
安装介质位置:/home/software/redis-2.6.6.tar.gz
要实现的机制是:redis一主一备,主机可读写,备机只读,客户端通过访问230这个虚拟IP来操作redis。
当备机宕机重启后,会自动恢复为redis备机,并同步主机数据。
当主机宕机重启后,原备机自动接管成为主机,原主机重启后成为备机30秒,从原备机同步数据,30秒后,原主机恢复为主机,原备机恢复为备机。
在redis使用频率很高的时候,主机宕机的一段时间内,可能有大量数据写入原备机,30秒同步时间未必足够,建议通过测试确定同步的时间。
下面出现的jeremiahxu.com是假设的密码。
1. 安装redis
# cd /home/software
# tar -zxvf redis-2.6.6.tar.gz
# mv /home/software/redis-2.6.6 /opt/redis
# cd /opt/redis
# make && make install
2. 修改配置文件
# vi /opt/redis/redis.conf
经常需要修改的参数包括:
daemonize yes
yes表示后台运行redis
loglevel debug
日志级别改成debug是用于开发和测试环境,生产环境建议还是换成notice或者warning级别。
logfile /var/log/redis.log
指定日志文件
databases 1
database的数量,默认是16,但是我只需要一个。
requirepass jeremiahxu.com
master的密码,slaver需要这个密码才能和master相连(客户端连接时也需要密码),主要是出于安全性考虑,如果你的网络环境比较“干净”,
那么就不需要设置密码了,因为redis多数情况是部署在内网的,外网无法访问。
masterauth jeremiahxu.com
slave连接master时用到的密码。
在备机上增加如下配置(主机不需要这句):
slaveof 192.168.193.240
3. 启动停止命令
启动:redis-server
指定配置文件的启动:/opt/redis/src/redis-server /opt/redis/redis.conf
停止:redis-cli shutdown
指定端口停止(没有使用默认端口启动时):redis-cli -p 6380 shutdown
如果使用了密码:redis-cli -a jeremiahxu.com shutdown
BTW:启动redis时要指定配置文件,不指定配置文件的话,redis并没有加载你安装好看到的那个默认的redis.conf,所以你修改了那个redis.conf而启动时不指定它的话,是没有用的。
4.配置成服务
vi /etc/init.d/redis
=======================================================
#!/bin/bash
#
# Startup script for the redis
#
# chkconfig: 345 80 15
# description: redis
# Source function library.p
. /etc/rc.d/init.d/functions
export REDIS_HOME=/opt/redis
case "$1" in
start)
$REDIS_HOME/src/redis-server $REDIS_HOME/redis.conf
;;
stop)
$REDIS_HOME/src/redis-cli -a jeremiahxu.com shutdown
;;
restart)
$REDIS_HOME/src/redis-cli -a jeremiahxu.com shutdown
$REDIS_HOME/src/redis-server $REDIS_HOME/redis.conf
;;
status)
$REDIS_HOME/src/redis-server -v
;;
*)
echo "Usage: $0 {start|stop|restart|status}"
esac
exit 0
=======================================================
别忘记增加执行权限:
chmod +x /etc/init.d/redis
5. 安装配置heartbeat
yum -y install heartbeat
heartbeat有三个配置文件:ha.cf、authkeys、haresources
vi /etc/ha.d/authkeys
===============================
auth 1
1 crc
===============================
vi /etc/ha.d/ha.cf
================================================
logfile /var/log/ha-log
logfacility local0
keepalive 1
deadtime 10
warntime 4
initdead 120
udpport 6940
ucast eth0 192.168.193.239 6940
auto_failback on
node centos-a
node centos-b
================================================
ha.cf这个配置文件的ucast参数,后面的ip地址要写双机集群中对方的ip和端口。
udpport参数最好改掉,我这里改成了6940,默认的694端口很可能会被rcp占用。
vi /etc/ha.d/haresources
==================================================================
centos-a IPaddr::192.168.193.230/24 redis-cluster
==================================================================
这个配置文件主备是一样的,包括前面那个值:centos-a,这个是主服务器的名字。
接着配置自动切换脚本:
vi /etc/ha.d/resource.d/redis-cluster
在主机上:
==================================================================
#!/bin/bash
#
# Startup script for the redis cluster
#
# chkconfig: 345 80 15
# description: redis cluster
# Source function library.p
. /etc/rc.d/init.d/functions
export REDIS_HOME=/opt/redis
case "$1" in
start)
$REDIS_HOME/src/redis-cli -a jeremiahxu.com slaveof 192.168.193.239 6379
sleep 30
$REDIS_HOME/src/redis-cli -a jeremiahxu.com slaveof NO ONE
;;
stop)
$REDIS_HOME/src/redis-cli -a jeremiahxu.com slaveof 192.168.193.239 6379
;;
esac
exit 0
==================================================================
在备机上:
==================================================================
#!/bin/bash
#
# Startup script for the redis cluster
#
# chkconfig: 345 80 15
# description: redis cluster
# Source function library.p
. /etc/rc.d/init.d/functions
export REDIS_HOME=/opt/redis
case "$1" in
start)
$REDIS_HOME/src/redis-cli -a jeremiahxu.com slaveof NO ONE
;;
stop)
sleep 30 && $REDIS_HOME/src/redis-cli -a jeremiahxu.com slaveof 192.168.193.240 6379 &
;;
esac
exit 0
==================================================================
redis-cluster是我自定义的切换脚本,名字其实是可以随便起的,但必须放到/etc/ha.d/resource.d/目录下或者/etc/init.d/目录,并且要赋予执行权限。
已有 0 人发表留言,猛击->>这里<<-参与讨论
ITeye推荐
- —软件人才免语言低担保 赴美带薪读研!—
模板方法模式:类的行为模式。一个抽象类,将部分逻辑以具体方法以及具体构造的形式实现,然后声明一些抽象方法来迫使子类实现剩余的逻辑。不同的子类可以以不同的方式实现这些抽象方法,从而对剩余的逻辑有不同的实现。它包括轮廓和具体逻辑,轮廓即为模板方法,具体逻辑为基本方法。
模板方法:定义在抽象类中,把基本操作方法组合在一起形成一个总的行为,由子类不加修改地完全继承下来。一个抽象类 可以有多个模板方法,一个模板方法可以调用任意多个具体方法。
基本方法:分为抽象方法、具体方法、钩子方法;具体方法由抽象类声明并实现,有些能起到工厂方法的作用。钩子方法由抽象类声明并实现,而子类回加以扩展。通常抽象类给出的是一个空实现或默认实现。
角色:
抽象模板角色:定义一个活多个抽象操作(基本操作),一边让子类实现;定义并实现一个模板方法。模板方法一般是一个具体方法,他给出了轮廓的骨架,而其中的逻辑的组成步骤在相应的抽象操作中,推迟到子类实现。
具体模板角色:实现父类所定义的一个或多个抽象方法,他们是一个轮廓的组成步骤;每个抽象模板角色都可以有任意多个具体模板角色与之对应,而每一个具体模板角色都可以给出这些抽象方法的不同实现,从而使得轮廓的实现各不相同。
先来个例子:
package cn.design.pattern.demo.templatemethod.demo.interesrate; public abstract class Account { protected String accountNum; public Account() { accountNum = null; } public Account(String accountNum) { this.accountNum = accountNum; } /** * 模板方法 * @return */ protected final double calculateRest() { double insertRate = doCalculateInterRate(); String accountType = doCalculateAccountType(); double amount = calculateAmount(accountType, accountNum); return amount * insertRate; } /** * 两个基本方法, 由子类实现 * @return */ protected abstract String doCalculateAccountType(); protected abstract double doCalculateInterRate(); /** * 基本方法,已经实现 * @param accountType * @param accountNum * @return */ protected final double calculateAmount(String accountType, String accountNum) { // 可能读取数据库数据 return 12334D; } } package cn.design.pattern.demo.templatemethod.demo.interesrate; public class MarketAccount extends Account { @Override protected String doCalculateAccountType() { return null; } @Override protected double doCalculateInterRate() { return 0; } } package cn.design.pattern.demo.templatemethod.demo.interesrate; public class CDAccount extends Account { @Override protected String doCalculateAccountType() { return null; } @Override protected double doCalculateInterRate() { return 0; } }
在我们之前接触到得HttpServlet,正是用了模板方法模式:service方法是模板方法,其中调用doXXX方法,而doXXX方法则由子类实现具体业务。
已有 0 人发表留言,猛击->>这里<<-参与讨论
ITeye推荐
- —软件人才免语言低担保 赴美带薪读研!—