> 监控报警 > zabbix环境搭建部署(一)

zabbix环境搭建部署(一)

监控报警  靠谱运维  2年前 (2017-11-30)  4845℃  0评论

一、zabbix介绍

zabbix官网:https://www.zabbix.com/

zabbix下载页面:https://www.zabbix.com/download

zabbix rpm包下载页面:http://repo.zabbix.com/zabbix/

1.1 zabbix简介

zabbix是一个基于WEB界面的提供分布式系统监视以及网络监视功能的企业级的开源解决方案。
zabbix能监视各种网络参数,保证服务器系统的安全运行;并提供灵活的通知机制以让系统管理员快速定位/解决存在的各种问题。
zabbix由2部分构成,zabbix server与可选组件zabbix agent。
zabbix server可以通过SNMP,zabbix agent,ping,端口监视等方法提供对远程服务器/网络状态的监视,数据收集等功能,它可以运行在Linux,Solaris,HP-UX,AIX,Free BSD,Open BSD,OS X等平台上。

说的直白一点,就是zabbix大家都很熟悉了,也是现在用的比较流行的一款分布式监控系统,当然现在Open-Falcon(小米监控)现在使用的人也越来越多了。

1.2 zabbix的组件

zabbix由以下几个组件部分构成:

Zabbix Server:负责接收agent发送的报告信息的核心组件,所有配置,统计数据及操作数据均由其组织进行。
Database Storage:专用于存储所有配置信息,以及由zabbix收集的数据。
Web interface:zabbix的GUI接口,通常与Server运行在同一台主机上。
Proxy:可选组件,常用于分布监控环境中,代理Server收集部分被监控端的监控数据并统一发往Server端(实现分布式监控专用组件非必要组件,被监控服务器过多或者跨机房可以使用此组件。)

Agent:部署在被监控主机上,负责收集本地数据并发往Server端或Proxy端。
注:zabbix node也是 zabbix server的一种 。不过现在已经基本弃用了。

1.3 zabbix监控环境中相关术语

主机(host):要监控的网络设备,可由IP或DNS名称指定

主机组(host group):主机的逻辑容器,可以包含主机和模板,但同一个组织内的主机和模板不能互相链接;主机组通常在给用户或用户组指派监控权限时使用

监控项(item):一个特定监控指标的相关的数据;这些数据来自于被监控对象;item是zabbix进行数据收集的核心,相对某个监控对象,每个item都由”key”标识
触发器(trigger):一个表达式,用于评估某监控对象的特定item内接收到的数据是否在合理范围内,也就是阈值;接收的数据量大于阈值时,触发器状态将从”OK”转变为”Problem”,当数据再次恢复到合理范围,又转变为”OK”
事件(event):触发一个值得关注的事情,比如触发器状态转变,新的agent或重新上线的agent的自动注册等
动作(action):指对于特定事件事先定义的处理方法,如发送通知,何时执行操作
报警升级(escalation):发送警报或者执行远程命令的自定义方案,如每隔5分钟发送一次警报,共发送5次等
媒介(media):发送通知的手段或者通道,如Email、Jabber或者SMS等
通知(notification):通过选定的媒介向用户发送的有关某事件的信息
远程命令(remote command):预定义的命令,可在被监控主机处于某特定条件下时自动执行
模板(template):用于快速定义被监控主机的预设条目集合,通常包含了item、trigger、graph、screen、application以及low-level discovery rule;模板可以直接链接至某个主机
应用(application):一组item的集合
web场景(web scennario):用于检测web站点可用性的一个或多个HTTP请求

前端(frontend):Zabbix的web接口

二、zabbix的安装

2.1 服务端的安装(Centos6)

(1). yum安装必要环境

# yum install httpd php http-devel php-devel php-pear php-xmlrpc php-bcmath mysql-connector-odbc mysql-devel libdbi-dbd-mysql httpd-manual mod_ssl mod_perl mod_auth_mysql php-gd php-xml php-mbstring php-ldap php-pear php-xmlrpc php-bcmath mysql-connector-odbc mysql-devel libdbi-dbd-mysql net-snmp-devel curl-devel unixODBC-devel OpenIPMI-devel java-devel -y

# yum install -y libssh2-devel

# yum install -y openldap openldap-devel

注(有两个yum单独列出来了,是因为我们的编译参数比较多,不yum上面两行的话会报错):

Bash
如果报错:configure: error: SSH2 library not found
就yum install -y libssh2-devel
如果报错:configure: error: Invalid LDAP directory - unable to find ldap.h
就:yum install openldap openldap-devel

(2). 配置php环境
sed -i “s/;date.timezone =/date.timezone = Asia\/Shanghai/g” /etc/php.ini
sed -i “s#max_execution_time = 30#max_execution_time = 300#g” /etc/php.ini
sed -i “s#post_max_size = 8M#post_max_size = 32M#g” /etc/php.ini
sed -i “s#max_input_time = 60#max_input_time = 300#g” /etc/php.ini
sed -i “s#memory_limit = 128M#memory_limit = 128M#g” /etc/php.ini
sed -i “s/;mbstring.func_overload = 0/mbstring.func_overload = 0\n/” /etc/php.ini

(3). 安装zabbix服务端

# wget prdownloads.sourceforge.net/zabbix/zabbix-2.4.8.tar.gz
# groupadd zabbix -g 201
# useradd -g zabbix -u 201 -m zabbix

# tar zxf zabbix-2.4.8.tar.gz
# cd zabbix-2.4.8

# ./configure –prefix=/usr/local/zabbix-2.4.8 –sysconfdir=/etc/zabbix –enable-server –enable-proxy –enable-agent –enable-ipv6 –with-mysql=/usr/bin/mysql_config –with-net-snmp –with-libcurl –with-openipmi –with-unixodbc –with-ldap –with-ssh2 –enable-java
# make && make install  #其实make install就可以了

# ln -s /usr/local/zabbix-2.4.8 /usr/local/zabbix

(4).添加zabbix到系统服务文件

# cat /etc/services |grep zabbix  #可以看一眼,没有就加上,默认已经加上了

Bash
zabbix-agent    10050/tcp               # Zabbix Agent
zabbix-agent 10050/udp # Zabbix Agent
zabbix-trapper 10051/tcp # Zabbix Trapper
zabbix-trapper 10051/udp # Zabbix Trapper

(5).mysql的配置

# vi /etc/my.cnf  #配置一下mysql配置文件,让其使用utf-8,并且对innodb做些设置,因为主要是写功能

Bash
[client]
port=3306
socket=/var/lib/mysql/mysql.sock
[mysqld]
port=3306
socket=/var/lib/mysql/mysql.sock
default-storage-engine=innodb
default-table-type=innodb
ignore-builtin-innodb
plugin-load=innodb=ha_innodb_plugin.so
plugin_dir=/usr/local//mysql/lib/plugin/
datadir=/mysqldata
skip-external-locking
character-set-server = utf8
collation-server=utf8_general_ci
#logs
slow_query_log
slow_query_log_file =/var/log/mysql/slowquery.log
long_query_time=2
log_error=/var/log/mysql/mysql-error.log
#limits
skip-name-resolve
max_connections=5000
back_log=300
table-cache=4096
max_allowed_packet =32M
max_heap_table_size =128M
key_buffer_size=128M
sort-buffer-size=16M
join-buffer-size=16M
net_buffer_length=8K
read_buffer_size=256K
read_rnd_buffer_size=256K
myisam_sort_buffer_size=8M
thread-cache-size=16
thread-concurrency=24
query-cache-size=2048M
query-cache-limit=4M
tmp_table_size=256M
log_warnings #innodb
innodb_file_per_table=1
innodb_file_io_threads=4
innodb_open_files=2048
innodb_buffer_pool_size=5G
innodb_additional_mem_pool_size=128M
innodb_thread_concurrency=16
innodb_max_dirty_pages_pct=90
user=mysql
# Disabling symbolic-links is recommended to prevent assorted security risks
symbolic-links=0 [mysqldump]
quick
max_allowed_packet=16M [myisamchk]
key_buffer_size=20M
sort_buffer_size=20M
read_buffer=2M
write_buffer=2M
[mysqld_safe]
log-error=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pid

# mkdir /mysqldata
# chown mysql:mysql /mysqldata/
# /etc/init.d/mysqld restart

(6). 导入zabbix数据库

# mysqladmin -uroot password ’123456′  #mysql初始是没有密码的,我们这里就设置个简单密码吧,实际生产密码很复杂
# mysql -uroot -p123456 -e ‘create database zabbix character set utf8;’
# mysql -uroot -p123456 -e “grant all privileges on zabbix.* to zabbix@localhost identified by ‘zabbix’;”
# mysql -uroot -p123456 -e “flush privileges;”
# mysql -uzabbix -pzabbix zabbix </root/zabbix-2.4.8/database/mysql/schema.sql   #这个sql文件的导入顺序不能变,不然要报错
# mysql -uzabbix -pzabbix zabbix </root/zabbix-2.4.8/database/mysql/images.sql
# mysql -uzabbix -pzabbix zabbix </root/zabbix-2.4.8/database/mysql/data.sql
(7).拷贝启动脚本并配置

# cp /root/zabbix-2.4.8/misc/init.d/fedora/core/zabbix_* /etc/init.d/
# sed -i “s#BASEDIR=/usr/local#BASEDIR=/usr/local/zabbix#” /etc/init.d/zabbix_server

# sed -i “s#BASEDIR=/usr/local#BASEDIR=/usr/local/zabbix#” /etc/init.d/zabbix_agentd

(8).zabbix主配置文件修改

# cat /etc/zabbix/zabbix_server.conf|grep -v “^#”|grep -v “^$”   #简单配置一下,主要是配置连接数据库的账号和密码

Bash
LogFile=/var/zabbix/zabbix_server.log
DBName=zabbix
DBUser=zabbix
DBPassword=zabbix
ListenIP=127.0.0.1

# mkdir /var/zabbix
# chown zabbix:zabbix /var/zabbix/
(9).拷贝网页文件到web站点目录下

# cp -r /root/zabbix-2.4.8/frontends/php /var/www/html/zabbix
# chown apache:apache /var/www/html/zabbix/conf  #此目录下,程序要创建一个php,当然不授权的话,等到安装到哪部,下载下php文件也可以。

(10).通过web页面配置zabbix

http://192.168.1.102/zabbix  #访问url格式是IP/zabbix的格式

#然后就按照提示下一步,该填写什么就填写什么了,这个web引导的安装界面比较简单。

#成功后安装,再次访问上面的url,就是登录页面了,默认的账号是admin,密码是zabbix。

2.2 服务端的安装(Centos7)

现在线上用Centos7系统的越来越多,zabbix的版本也变为了3系列,虽然我线上的是zabbix是2.4系列的,但是用新版本的是一个趋势,后面的操作都是以新版本为例。

(1). yum安装必要环境

# yum install httpd php php-devel php-pear php-xmlrpc php-bcmath  mariadb mariadb-server mariadb-devel httpd-manual mod_ssl  php-gd php-xml php-mbstring php-ldap php-pear php-xmlrpc php-bcmath libdbi-dbd-mysql net-snmp-devel curl-devel unixODBC-devel OpenIPMI-devel java-devel -y   #这里主要区别是由mysql改成了mariadb。

# yum install -y libssh2-devel

# yum install -y openldap openldap-devel

(2). 配置php环境
sed -i “s/;date.timezone =/date.timezone = Asia\/Shanghai/g” /etc/php.ini
sed -i “s#max_execution_time = 30#max_execution_time = 300#g” /etc/php.ini
sed -i “s#post_max_size = 8M#post_max_size = 32M#g” /etc/php.ini
sed -i “s#max_input_time = 60#max_input_time = 300#g” /etc/php.ini
sed -i “s#memory_limit = 128M#memory_limit = 128M#g” /etc/php.ini
sed -i “s/;mbstring.func_overload = 0/mbstring.func_overload = 0\n/” /etc/php.ini

(3). 安装zabbix服务端

# wget https://sourceforge.net/projects/zabbix/files/ZABBIX%20Latest%20Stable/3.2.6/zabbix-3.2.6.tar.gz

# groupadd zabbix -g 201
# useradd -g zabbix -u 201 -m zabbix

# tar zxf zabbix-3.2.6.tar.gz
#cd zabbix-3.2.6
# ./configure –prefix=/usr/local/zabbix-3.2.6  –sysconfdir=/etc/zabbix  –enable-server  –enable-proxy  –enable-agent  –enable-ipv6  –with-mysql=/usr/bin/mysql_config  –with-net-snmp  –with-libcurl  –with-openipmi  –with-unixodbc  –with-ldap  –with-ssh2  –enable-java
# make install
# ln -s /usr/local/zabbix-3.2.6 /usr/local/zabbix

注:要支持vmware的监控zabbix在编译时必须 configure 里有 –with-libxml2 –with-libcurl,前者用来解析调用SOAP接口返回的XML,后者用来调用vcenter的SOAP接口。

下面让我们了解下./configure后面跟的参数的含义:

# ./configure  –help

Bash
可选功能:
--enable-static #构建静态链接的二进制文件
--enable-server #打开Zabbix服务器的构建
--enable-proxy #打开Zabbix代理的构建
--enable-agent #打开Zabbix代理和客户端实用程序的构建
--enable-java #打开Zabbix支持监控java,zabbix 监控jmx 需要--enable-java
--enable-ipv6 #打开zabbix对ipv6的支持
可选包:
--with-mysql[=ARG] #使用MySQL客户端库[default = no],可选指定mysql_config的路径
--with-jabber[=DIR] #包括Jabber支持[default = no]。 DIR是iksemel库安装目录。如果要使用Jabber协议进行消息传递.
--with-libxml2[=ARG] #使用libxml2客户端库[default = no],可选地指定xml2-config的路径.如果要使用XML库
--with-unixodbc[=ARG] #使用ODBC驱动程序对unixODBC包[default = no],可选地指定odbc_config二进制的完整路径。如果要使用unixODBC库
--with-net-snmp[=ARG] #使用Net-SNMP包[default = no],可选地指定net-snmp-config的路径.如果要使用Net-SNMP库
--with-ssh2[=DIR] #使用SSH2包[default = no],DIR是SSH2库的安装目录。如果要使用基于SSH2的检查
--with-openipmi[=DIR] #包括OPENIPMI支持[default = no]。 DIR是OPENIPMI基本安装目录,默认是通过OPENIPMI文件的一些常见位置进行搜索。如果要检查IPMI设备
--with-mbedtls[=DIR] #使用mbed TLS(PolarSSL)软件包[default = no],DIR是libpolarssl安装目录。如果要使用由mbed TLS(PolarSSL)库提供的加密
--with-gnutls[=DIR] #使用GnuTLS包[default = no],DIR是libgnutls的安装目录。如果要使用GnuTLS库提供的加密
--with-openssl[=DIR] #使用OpenSSL包[default = no],DIR是libssl和libcrypto的安装目录。如果要使用OpenSSL库提供的加密
--with-ldap[=DIR] #包括LDAP支持[default = no]。DIR是LDAP基本安装目录,默认是通过LDAP文件的多个常见位置进行搜索。如果要检查LDAP服务器.
--with-libcurl[=DIR] #使用cURL包[default = no],可选地指定curl-config的路径.如果要使用cURL库
如果要指定iconv安装目录:
--with-iconv=[DIR] #使用iconv从给定的基本安装目录(DIR),默认是通过一些常见的地方搜索iconv文件。
--with-iconv-include=[DIR] #使用iconv包含给定路径的头。
--with-iconv-lib=[DIR] #从给定的路径使用iconv库。

(4). 导入zabbix数据库

# systemctl start mariadb.service

# mysqladmin -uroot password ’123456′

# mysql -uroot -p123456 -e ‘create database zabbix character set utf8;’
# mysql -uroot -p123456 -e “grant all privileges on zabbix.* to zabbix@localhost identified by ‘zabbix’;”
# mysql -uroot -p123456 -e “flush privileges;”

# mysql -uzabbix -pzabbix zabbix </root/zabbix-3.2.6/database/mysql/schema.sql

# mysql -uzabbix -pzabbix zabbix </root/zabbix-3.2.6/database/mysql/images.sql

# mysql -uzabbix -pzabbix zabbix </root/zabbix-3.2.6/database/mysql/data.sql

(5).拷贝启动脚本并配置

# cp /root/zabbix-3.2.6/misc/init.d/fedora/core/zabbix_* /etc/init.d/
# sed -i “s#BASEDIR=/usr/local#BASEDIR=/usr/local/zabbix#” /etc/init.d/zabbix_server

# sed -i “s#BASEDIR=/usr/local#BASEDIR=/usr/local/zabbix#” /etc/init.d/zabbix_agentd

(6).zabbix主配置文件修改

# cat /etc/zabbix/zabbix_server.conf|grep -v “^#”|grep -v “^$”   #简单配置一下,主要是配置连接数据库的账号和密码

Bash
LogFile=/var/zabbix/zabbix_server.log
DBName=zabbix
DBUser=zabbix
DBPassword=zabbix
ListenIP=127.0.0.1

# mkdir /var/zabbix
# chown zabbix:zabbix /var/zabbix/

(7).拷贝网页文件到web站点目录下

# cp -r /root/zabbix-3.2.6/frontends/php /var/www/html/zabbix
# chown apache:apache /var/www/html/zabbix/conf  #此目录下,程序要创建一个php,当然不授权的话,等到安装到哪部,下载下php文件也可以。

(8).通过web页面配置zabbix

http://192.168.1.103/zabbix  #访问url格式是IP/zabbix的格式

#然后就跳到登录界面了,用户名是admin,密码是zabbix

2.3 server web展示如何显示中文

#点击右上角的小人图标

# /etc/init.d/zabbix_server start  #启动zabbix_server服务

# /etc/init.d/zabbix_agentd start  #本机的agent也启动起来,为了出图查看效果。

#从首页看都已经变成了中文。

#但是存在一个问题请看下图:

#由上图可以看出,所有的汉字都是白框没有显示出来。

解决办法:

进入到本地windos目录下:C:\Windows\Fonts(以微软雅黑msyh.ttf为例)。

将windows端的msyh.ttf文件上传到服务器端的/var/www/html/zabbix/fonts目录中。

#ls -l /var/www/html/zabbix/fonts/msyh.ttf  #查看一下,确实存在了

Bash
-rw-r--r-- 1 root root 21767952 6月  11 2009 /var/www/html/zabbix/fonts/msyh.ttf

# vim /var/www/html/zabbix/include/defines.inc.php +45

define(‘ZBX_GRAPH_FONT_NAME’,           ‘DejaVuSans’);  替换为:define(‘ZBX_GRAPH_FONT_NAME’,           ‘msyh’);   #就是DejaVuSans替换为msyh

#再次刷新web页面,在数据图上面的中文字体也就都显示出来了。

2.4 zabbix客户端的安装

# wget prdownloads.sourceforge.net/zabbix/zabbix-3.2.6.tar.gz
# groupadd zabbix -g 201
# useradd -g zabbix -u 201 -m zabbix
# tar zxf zabbix-3.2.6.tar.gz
# cd zabbix-3.2.6

# ./configure –prefix=/usr/local/zabbix-3.2.6 –sysconfdir=/etc/zabbix  –enable-agent

# make install
# ln -s /usr/local/zabbix-3.2.6 /usr/local/zabbix

# cp /root/zabbix-3.2.6/misc/init.d/fedora/core/zabbix_agentd /etc/init.d/
# sed -i “s#BASEDIR=/usr/local#BASEDIR=/usr/local/zabbix#” /etc/init.d/zabbix_agentd

# vim /etc/zabbix/zabbix_agentd.conf  #就先修改一个地方,让Server端指向zabbix_server的IP地址
Server=192.168.1.103
# /etc/init.d/zabbix_agentd restart
2.5 zabbix服务器端添加刚刚添加的zabbix客户端主机

首先创建一个主机组

配置==》主机群组==》创建主机群组(web页面右上角)==》添加组名,如:Zabbix agents(在弹出框中输入组名)==>添加

添加一个主机

配置==》主机==》右上角在群组那里选择Zabbix agents==》点击创建主机   #如下图

下面是主机的添加过程:

给此主机引用一条模板:

在上面那张图片中可以看到主机的右边有个模板,点击模板,链接指示器那一栏点击选择按钮,然后选择你要添加的模板,点击添加,然后返回到模板界面之后,再点击下面的添加按钮,然后点击更新。

下面是添加完的效果图:

最后看下图形效果:

检测中==》图形==》然后就是选择要看什么了,如下图:

到此一个简单的zabbix服务端监控一个客户端的操作就算结束了。

有一个小问题:

Too many processes on Zabbix server

Too many processes on 192.168.1.104

配置==》模板==》Template OS Linux ==》触发器 ==>Too many processes on {HOST.NAME}(点击)==》表达式改为:{Template OS Linux:proc.num[].avg(5m)}>1000==>更新

#因为原来触发器里面的进程数太少了,zabbix本身就会启动二三十个左右的进程,所以很容易就超了,把进程监控调大一点。

转载请注明:靠谱运维 » zabbix环境搭建部署(一)

喜欢 (4)or分享 (0)

zabbix环境搭建部署(一)的更多相关文章

  1. zabbix环境搭建

    zabbix介绍 zabbix是一个开源的监控软件集成了nagos和cat的优势 而且有很多自带的插件可以使用,而且还有api接口供我们使用 zabbix还支持自定义监控项 初始环境- centos ...

  2. 08- Tomcat入门与环境搭建部署

    环境搭建:网站文件(开发人员提供),相关软件(web服务器,应用服务器,数据库软件),硬件(服务器设备上),网络环境. 开发人员提供:部署文档说明书(操作系统版本,硬件配置,服务器软件及相关版本,部署 ...

  3. Spark集群环境搭建——部署Spark集群

    在前面我们已经准备了三台服务器,并做好初始化,配置好jdk与免密登录等.并且已经安装好了hadoop集群. 如果还没有配置好的,参考我前面两篇博客: Spark集群环境搭建--服务器环境初始化:htt ...

  4. (转载):ganglia之环境搭建部署

    转载:http://www.360doc.com/content/19/0211/12/62122823_814215724.shtml 借鉴:https://blog.csdn.net/lswnew ...

  5. k8s1.20环境搭建部署(二进制版本)

    1.前提知识 1.1 生产环境部署K8s集群的两种方式 kubeadm Kubeadm是一个K8s部署工具,提供kubeadm init和kubeadm join,用于快速部署Kubernetes集群 ...

  6. 深度学习环境搭建部署(DeepLearning 神经网络)

    工作环境 系统:Ubuntu LTS 显卡:GPU NVIDIA驱动:410.93 CUDA:10.0 Python:.x CUDA以及NVIDIA驱动安装,详见https://www.cnblogs ...

  7. Drupal 8 环境搭建部署

    运行环境安装 系统:Ubuntu Server 16.04  (ubuntu-16.04.4-server-amd64.iso) Web服务器:Apache / 2.4.18 数据库:Mysql / ...

  8. 【JAVA WEB教程】jsp环境搭建+部署网站(eclipse+tomcat)【详细+图文】

    下载tomcat7.X   下载地址为:http://tomcat.apache.org/download-70.cgi 下载完成之后就开始安装   Next   I Agree   选中所有的复选框 ...

  9. linux环境下完成jenkins的环境搭建

    环境搭建部署: 请完成jenkins的环境搭建,需安装tomcat,mysql. Jenkins 地址:  https://jenkins.io/download/ 步骤分析: 1.全部操作使用普通用 ...

随机推荐

  1. Spring Boot2 系列教程(二十五)Spring Boot 整合 Jpa 多数据源

    本文是 Spring Boot 整合数据持久化方案的最后一篇,主要和大伙来聊聊 Spring Boot 整合 Jpa 多数据源问题.在 Spring Boot 整合JbdcTemplate 多数据源. ...

  2. 力扣(LeetCode)平方数之和 个人题解

    给定一个非负整数 c ,你要判断是否存在两个整数 a 和 b,使得 a2 + b2 = c. 示例1: 输入: 5 输出: True 解释: 1 * 1 + 2 * 2 = 5 示例2: 输入: 3 ...

  3. Obtaining the backtrace - libunwind

    Sometimes when working on a large project, I find it useful to figure out all the places from which ...

  4. 添加ssh服务构建新镜像-docker commit 方式01

    添加ssh服务构建新镜像-docker commit 方式 1:docker commit构建自定义镜像---一般不推荐使用这种方式构建新镜像 1:ubuntu基础镜像下载 ubuntu@ubuntu ...

  5. 新闻实时分析系统 Spark Streaming实时数据分析

    1.Spark Streaming功能介绍1)定义Spark Streaming is an extension of the core Spark API that enables scalable ...

  6. 【Luogu P1714】切蛋糕(面向对象编程首次尝试?)

    Luogu P1714 题目的大意就是给定一个长度为n的序列,求出这个序列中长度不超过m的子串的最大和 很容易想出的一个解法就是枚举起点终点,直接暴力扫一遍得出答案. 当然也很容易发现这种做法肯定会T ...

  7. 实现自定义的参数解析器——HandlerMethodArgumentResolver

    1.为什么需要自己实现参数解析器 我们都知道在有注解的接口方法中加上@RequestBody等注解,springMVC会自动的将消息体等地方的里面参数解析映射到请求的方法参数中. 如果我们想要的信息不 ...

  8. 炸裂函数explode

    ateral viem 表的关联只能和explode使用 hive> select explode(info) from t_map where id=1; hive> create ta ...

  9. 转载 :c# 获取net framework 版本(Environment 类)

    源链接:http://www.cnblogs.com/tobecrazy/p/3362446.html 根据自己使用情况,添加了部分备注 1.获取当前操作系统版本信息 使用Environment.OS ...

  10. LESSON 3- Discrete Memory-less Sources

    1.     Entropy H[X] - bounds on Lmin 2.      Huffman’s algorithm for optimal source code