豫ICP备17040950号-2

分布式系统:CAP

一直不太理解CAP,最近好像有点感觉了,这里写下来,先介绍下CAP的定义:

  • C:一致性。写完数据后,立马能看到最新数据。
  • A:可用性。所有请求必须有响应。
  • P:分区容错性。网络或服务器故障不会导致系统不可用。
    CAP定律这样定义,任何一个分布式系统不可能同时满足这三种特性。下面做一下简单的分析:
    一般的大型系统都要求做到分区容错性,如:提供网络、应用服务器和数据服务器的灾备,这样我们就只能在C和A中做出选择,如果选择了C,就要求写操作同时向集群内的多个服务器同步的写,这样识别效率就低,在高并发的场景下,操作很容易超时,导致不可用。相对于A,我们更需要牺牲C,这样最终就采用:最终一致性。

美国程序员,差距就在这五点

心态差距

近年来由于互联网的迅速发展,全国各地,IT人才的需求量都出现了飞跃式的增长,程序员的薪资也明显高于其他行业。

但在国内,真正因为热爱编程而从事这份工作的人其实并不多,很多人学习程序想得都是这个行业火,赚钱快,入行门槛低。什么技术火就学什么,然后进入一个大公司,做几个成功的项目,积累工作经验,几年以后自己当个小管理,拿着十几万,或几十万的工资,再无追求的过着小日子就好。

甚至到了30岁,如果没能进入管理层,大多数人都会考虑转行,或仅靠自身的知识累积开始创业。

Linux,Android 句柄是什么 ?

1.句柄就是一个标识符,只要获得对象的句柄,我们就可以对对象进行任意的操作。

2.句柄不是指针,操作系统用句柄可以找到一块内存,这个句柄可能是标识符,map的key,也可能是指针,看操作系统怎么处理的了。
fd算是在某种程度上替代句柄吧;
Linux 有相应机制,但没有统一的句柄类型,各种类型的系统资源由各自的类型来标识,由各自的接口操作。

Shell脚本编程——下

运算符

算术运算符

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#!/bin/sh

a=10
b=20
echo "a=$a, b=$b"
val=`expr $a + $b`
echo "a + b : $val"
val=`expr $a - $b`
echo "a - b : $val"
val=`expr $a \* $b`
echo "a * b : $val"
val=`expr $b / $a`
echo "b / a : $val"
val=`expr $b % $a`
echo "b % a : $val"
if [ $a == $b ]
then
echo "a is equal to b"
fi
if [ $a != $b ]
then
echo "a is not equal to b"
fi