Bootstrap

大数据学习之Redis 缓存数据库二,Scala分布式语言一

一.Redis 缓存数据库二

26.Redis数据安全_AOF持久化机制

27.Redis数据安全_企业中该如何选择持久化机制

28.Redis集群_主从复制概念

29.Redis集群_主从复制搭建

30.Redis集群_主从复制原理剖析

31.Redis集群_哨兵监控概述

32.Redis集群_配置哨兵监控

33.Redis集群_哨兵监控原理剖析

34.Redis集群_哨兵监控故障转移监控

35.Redis集群_Cluster模式概述

36.Redis集群_Cluster模式搭建

37.Redis集群_Cluster模式原理

38.Redis集群_JAVA操作Redis集群

39.Redis企业级解决方案_Redis脑裂

40.Redis企业级解决方案_缓存预热

41.Redis企业级解决方案_缓存穿透

42.Redis企业级解决方案_缓存击穿

43.Redis企业级解决方案_缓存雪崩

44.Redis企业级解决方案_Redis开发规范

value 设计
拒绝 bigkey
防止网卡流量、慢查询, string 类型控制在 10KB 以内, hash
list set zset 元素个数不要超过 5000
#   表名 主键 主键值 存储列名字
set user:user_id:1:name baizhan
set user:user_id:1:age 20
# 查询这个用户
keys user:user_id:9*
162 命令使用
1 、禁用命令
禁止线上使用 keys flushall flushdb 等,通过 redis
rename 机制禁掉命令,或者使用 scan 的方式渐进式处理。
2 、合理使用 select
redis 的多数据库较弱,使用数字进行区分,很多客户端支持较
差,同时多业务用多数据库实际还是单线程处理,会有干扰。
3 、使用批量操作提高效率
原生命令:例如 mget mset
非原生命令:可以使用 pipeline 提高效率。
注意:
但要注意控制一次批量操作的 元素个数 ( 例如 500 以内,实
际也和元素字节数有关 )
4 、不建议过多使用 Redis 事务功能
Redis 的事务功能较弱 ( 不支持回滚 ) ,而且集群版本 ( 自研和官
) 要求一次事务操作的 key 必须在一个 slot 上。
客户端使用
Jedis https://github.com/xetorthio/jedis 重点推荐
1
Spring Data redis https://github.com/spring-projects/spring-data-redis 使用 Spring 框架
时推荐
2
Redisson https://github.com/mrniko/redisson 分布式锁、阻塞队列的时重点推荐
3
1 、避免多个应用使用一个 Redis 实例
不相干的业务拆分,公共数据做服务化。
2 、使用连接池
可以有效控制连接,同时提高效率,标准使用方式:
163 实时学习反馈
1.Redis 技术中下列符合 key 设计 __
A
user.id
B
user.id.1.age
C
user:id.1.age
D
user:id:1:age
答案
1=>C
执行命令如下:
Jedis jedis = null;
try {
  jedis = jedisPool.getResource();
// 具体的命令
  jedis.executeCommand()
} catch (Exception e) {
  logger.error("op key {} error: " +
e.getMessage(), key, e);
} finally {
// 注意这里不是关闭连接,在 JedisPool 模式下, Jedis 会被
归还给资源池。
if (jedis != null)
      jedis.close();
}

45.Redis企业级解决方案_数据一致性

二.Scala分布式语言一

2.1 Scala介绍与安装

1. 课程介绍

2. 什么是Scala

3. 为什么学习Scala

4. 六大特性

5. Scala环境安装

6. Idea插件安装

7. 第一个程序

8. 第一个程序简介

9. 查看字节码文件

2.2 Scala基础

10. 标识符_基本规则

Scala 可以使用两种形式的标识符,字符 + 数字和符号。
1
标识符使用字母或是下划线开头,后面可以接字母或是数
字。
     
LocalVariableTable :
       
Start   Length   Slot   Name  
Signature
           
0       17     0   this  
Lcn / itbaizhan / chapter01 / HelloWorld2$ ;
           
0       17     1   args  
[ Ljava / lang / String ;
   
MethodParameters :
     
Name                           Flags
     
args                           final
}
SourceFile : "HelloWorld2.scala"
Error : unknown attribute
ScalaInlineInfo : length = 0xE
01 01 00 02 00 0 A 00 09 01 00 0 D 00 0 E
01
Error : unknown attribute
Scala : length = 0x0
package cn . itbaizhan . chapter02
// 标识符的基本规则
object Identifier1 {
def main ( args : Array [ String ]): Unit = {
   
/*scala 的标识符和 java 的标识符基本一致
     
1. 可以使用字母、数字,下划线, $( 不建议使用 )
24 2
Scala 内部实现时会使用转义的标识符,比如 :-> 使用
$colon$minus$greater 来表示这个符号。因此如果你需要在
Java 代码中访问 :-> 方法,你需要使用 Scala 的内部名称
$colon$minus$greater
     
2. 是区分大小写的。
     
3. 长度是没有限制的。
     
4. 数字不能为标识符的开头
     
5. 关键字不能直接用来作为标识符
   
*/
   
var name = "tuhao1"
   
var naMe = "tuhao2"
   
var name1 = "diaosi"
   
//var 2name = "baifumei"// 错误的
   
//var def = "aitucuo"// 错误的
   
var name_ = "baifumei2"
}
}
package cn . itbaizhan . chapter02
object Identifier2 {
def main ( args : Array [ String ]): Unit = {
   
// 不建议使用特殊符号做标识符
   
// 编译后将 > 转义为 $greater ,所以我们使用
$ 开头的标识符容易产生冲突
   
val > = "tuhao"
   
println ( > ) //tuhao
   
//val $greater = "diaosi"//
   
// 下划线不要 直接作为标识符的名称
   
/*val _ = "username"
   
println(_)// 运行时出现异常 */
25 java 代码如下:
"$" 开头的标识符为保留的 Scala 编译器产生的标识符使
用,应用程序应该避免使用 "$" 开始的标识符,以免造成冲
突。
3
Scala 的命名规则采用和 Java 类似的 驼峰命名规则,首字符
小写,比如 toString 。类名的首字符还是使用大写。
4
避免使用以下划线结尾的标识符以避免冲突。符号标识符包
含一个或多个符号,如 + : ? 等,比如 :
}
def method (): String = {
   
"method() 被调用了 .."
}
def : -> (): Unit = {
   
println ( ":->() 被调用了 .." )
}
}
package cn . itbaizhan . chapter02 ;
public class Identifier2Java {
   
public static void main ( String [] args )
{
       
/*String result =
Identifier2.method();
       
System.out.println(result);*/
       
// 调用 Identifier2 中的 :->()
     
Identifier2 . $colon$minus$greater ();
  }
}
+ ++ ::: < ?> :->
26 5
可以在反引号之间使用任何有效的 Scala 标识符, Scala 将它
们解释为一个 Scala 标识符,一个典型的使用为 Thread
yield 方法, 在 Scala 中你不能使用 Thread.yield() 是因为
yield Scala 中的关键字,如下方式使用。
package cn . itbaizhan . chapter02
// 了解即可
object Identifier3 {
def main ( args : Array [ String ]): Unit = {
   
val ## = "tuohao"
   
val @@ = "diaosi"
   
val + = "tuhao1"
   
val - = "tuhao1"
   
val * = "tuhao1"
   
val / = "tuhao1"
   
val % = "tuhao1"
   
val < = "tuhao1"
   
val :: = "tuhao1"
   
val ? = "tuhao1"
}
}
package cn . itbaizhan . chapter02
// 关键字作为标识符如何解决
object Identifier4 {
def main ( args : Array [ String ]): Unit = {
   
// 以下两个代码 编译错误
   
/*val def = " 主函数变量 "
   
val private = "test1"*/
   
// 如果需要使用关键字作为标识符,需要使用反引号
   
val `def` = " 主函数变量 "
   
val `private` = "test1"
27 abstract
case
catch
class
def
do
else
extends
false
final
finally
for
forSome
if
implicit
import
lazy
match
new
null
object
override
package
private
protected
return
sealed
super
this
throw
trait
try
true
type
val
var
while
with
yield
-
:
=
=>
<-
<:
<%
>:
#
@
下表列出了 scala 保留关键字,我们不能使用以下关键字作为
变量名:
实时效果反馈
1. 关于 Scala 标识符的描述,错误的是:
A
标识符使用字母或是下划线开头,后面可以接字母或是数
字。
B
标识符命名规则采用和 Java 类似的 camel 命名规则,首字
符小写,比如 toString 。类名的首字符还是使用大写。。
   
println ( `def` )
   
Thread . `yield` ()
}
}

11.标识符_特殊符号

12.标识符_关键字处理方案

13.变量

2.2 变量
变量是一种使用方便的占位符,用于引用计算机内存地址,变
量创建后会占用一定的内存空间。基于变量的数据类型,操作系统
会进行内存分配并且决定什么将被储存在保留内存中。因此,通过
给变量分配不同的数据类型,你可以在这些变量中存储整数,小数
或者字母。
变量的类型在变量名之后等号之前声明。
var/val 变量名 :变量类型 = 变量值 // :变量类型 可以省略。
变量的类型如果能够通过变量值推断出来,那么可以省略类型
声明,这里的省略,并不是不声明,而是由 Scala 编译器在编译时自
动声明编译的。
29 Java 语法中变量在使用前进行初始化就可以,但是 Scala 语法中
是不允许的,必须
显式
进行初始化操作。
值可以改变的变量,被称为可变变量。使用 var 进行声明,值可
以改变,但是类型不能改变。
值一旦初始化后无法改变的变量,称之为不可变变量(也被称
为常量)。 Scala 中不可变变量使用关键字 val 进行声明 , 类似于 Java
语言中的 final 关键字
object ScalaVarVal {
def main ( args : Array [ String ]): Unit = {
   
// 名称
   
var name = "GTJin"
   
// 年龄
   
var age = 30
   
// 城市
   
val city = "beijing"
}
}
var address // 错误
var phone = "13812345678" // 正确的
var phone = "13812345678" // 正确的
phone = "13888888888" // 值可以改变
phone = 123 // 类型无法改变,也就是无法从 String 改为
Int
// 城市
val city : String = "beijing"
city = "ShangHai" // 错误
city = true // 错误
30 实时效果反馈
1. 关于 Scala 变量的描述,错误的是:
A
变量是一种使用方便的占位符,用于引用计算机内存地址。
B
变量创建后会占用一定的内存空间。
C
可变变量,使用 var 进行声明,值和类型都可以改变。
D
不可变变量(常量)使用 val 进行声明,值和类型都不可以
改变。
答案:
1=>C 可变变量,使用 var 进行声明,值可以改变但类型不可以
改变。

14.数据类型一

15.数据类型二

package cn . itbaizhan . chapter02
object DateType {
def main ( args : Array [ String ]): Unit = {
   
var bt : Byte = 10
   
var st : Short = 32675
   
var it : Int = 100000
   
var lg : Long = 10000000L
   
var ft : Float = 3.14f
   
var ft1 = 3.14f // 自动类型推测出为 Float
   
var db : Double = 8.8
   
var ca : Char = 'A'
   
var name : String = "gtjin"
   
var flag : Boolean = true
   
//Unit 类型的对象 只有一个值 就是 ()
   
var result : Unit = method ()
   
println ( result )
}
def method (): Unit = {
   
println ( "method" )
}
}
33 实时效果反馈
1. 关于 Scala 数据类型的描述,错误的是:
A
Byte 8 位有符号补码整数。数值区间为 -127 128
B
Int 32 位有符号补码整数。数值区间为 -2147483648
2147483647
C
Long 64 位有符号补码整数。数值区间为
-9223372036854775808 9223372036854775807
D
Boolean 类型的值为 true false
答案:
1=>A 区间为 -128 127

16.类型转换一

17.类型转换二

18.分支控制

19.循环控制_to和until

20.循环控制_for循环一

21.循环控制_for循环二

22.循环控制_for循环三

23.循环控制_for循环四

24.循环控制_while和do while

25.循环中段

26.字符串_String一

27.字符串_String二

28.字符串_StringBuilder

29.输入输出_控制台输入

30.输入输出_本地文件输入

31.输入输出_互联网文件输入

32.输入输出_写文件操作

package cn . itbaizhan . chapter02
// 导入相关类
import java . io .{ File , PrintWriter }
// 输出内容到文件 ( 写入内容到文件中 )
//Scala 进行文件写操作用的是 java IO
object OutFile {
def main ( args : Array [ String ]): Unit = {
   
// 创建写文件的对象
   
// 默认写到项目的根目录下
   
val writer = new PrintWriter ( new
File ( "out.txt" ))
   
// 写内容到文件,为了提高效率,会将写的内容放入
到缓冲区中,达到一定阈值时在刷到文件中
   
writer . write ( "tuhao\n" )
   
writer . write ( "diaosi\n" )
   
writer . write ( "baifumei\n" )
   
// 手动刷新缓冲区
   
writer . flush ()
   
// 关闭输出流对象
   
writer . close ()
}
}

2.3 基础功能搭建

33.函数和方法的区别

3.1 函数和方法区别
Scala 中存在方法与函数两个不同的概念,二者在语义上的区别很小。 scala 方法是类的一部
分,而函数是一个对象,可以赋值给一个变量,也可以作为方法或其它函数的参数。换句话来
说在类中定义的即是方法。 scala 中的方法跟 Java 的类似,方法是组成类的一部分。 scala
的函数则是一个完整的对象。
1
Scala 中的方法和函数从语法概念上来讲,一般不好区分,所以简单的理解就是:方法也是函
数。只不过类中声明的函数称之为方法,其他场合声明的就是函数了。类中的方法是有重载和
重写的。而函数可就没有重载和重写的概念了,但是函数可以嵌套声明使用,方法就没有这个
能力了,勿忘我哦

34.函数定义_无参无返回值函数

35.函数定义_有参无返回值

36.函数定义_无参有返回值

37.函数定义_有参有返回值

38.函数定义_总结

39.不定参数的函数一

40.不定参数的函数二

41.默认值参数函数

42.函数至简原则一

43.函数至简原则二

44.函数作为值一

45.函数作为值二

;