0%

当前大数据发展有三大趋势: 数据仓库往数据湖方向发展、批处理往流式处理发展、本地部署往云模式发展。数据湖作为最近两年兴起的热点概念,各大互联网公司都在对其研究和探索。本文参考了阿里、腾讯和网易等公司的一些资料,将告诉你数据湖到底是什么?有什么用?

https://xie.infoq.cn/article/7f01991ac2f3b6ef0423be513

阅读全文 »

问题描述

SpringBoot项目,本机运行正常,打war包放到服务器的Tomcat中之后无法访问,404.

查看了Tomcat的catalina.日志,发现报错:

More than one fragment with the name [org_apache_tomcat_websocket] was found.This is not legal with relative ordering. See section 8.2.2 2c of the Servlet specification for details. Consider using absolute ordering.

解决办法

把Tomcat7 换成Tomcat8

1、修改auto_master

编译 /etc/auto_master 文件,注释掉或者移除以 /home 开头的那一行,保存。

1
sudo vim /etc/auto_master

会提示"/etc/auto_master" [readonly] 8L, 196C ,文件不可编辑

可以使用命令

1
sudo nano /etc/auto_master

注释掉 /home 哪一行,如下所示:

1
2
3
4
5
6
7
8
9
#

# Automounter master map
#
+auto_master # Use directory service
/net -hosts -nobrowse,hidefromfinder,nosuid
#/home auto_home -nobrowse,hidefromfinder
/Network/Servers -fstab
/- -static

2、回到根目录,创建文件夹

1
2
3
cd /  (这一步很重要)
sudo automount (必须在/目录下执行)
mkdir /home/config

3、此目录是mac系统保留的目录,升级或修复系统都会抹除此目录下的数据,如果一定要使用,建议创建一个链接目录来存储数据,执行以下命令:

1
sudo ln -s /Users/linjian/config /home/config

Linux 查看端口占用情况可以使用 lsofnetstat 命令。


lsof

lsof(list open files)是一个列出当前系统打开文件的工具。

lsof 查看端口占用语法格式:

1
lsof -i:端口号

实例

查看服务器 8000 端口的占用情况:

1
2
3
# lsof -i:8000
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
nodejs 26993 root 10u IPv4 37999514 0t0 TCP *:8000 (LISTEN)

可以看到 8000 端口已经被轻 nodejs 服务占用。

lsof -i 需要 root 用户的权限来执行,如下图:

更多 lsof 的命令如下:

1
2
3
4
5
6
7
8
9
lsof -i:8080:查看8080端口占用
lsof abc.txt:显示开启文件abc.txt的进程
lsof -c abc:显示abc进程现在打开的文件
lsof -c -p 1234:列出进程号为1234的进程所打开的文件
lsof -g gid:显示归属gid的进程情况
lsof +d /usr/local/:显示目录下被进程开启的文件
lsof +D /usr/local/:同上,但是会搜索目录下的目录,时间较长
lsof -d 4:显示使用fd为4的进程
lsof -i -U:显示所有打开的端口和UNIX domain文件

netstat

netstat -tunlp 用于显示 tcp,udp 的端口和进程等相关情况。

netstat 查看端口占用语法格式:

1
netstat -tunlp | grep 端口号
  • -t (tcp) 仅显示tcp相关选项
  • -u (udp)仅显示udp相关选项
  • -n 拒绝显示别名,能显示数字的全部转化为数字
  • -l 仅列出在Listen(监听)的服务状态
  • -p 显示建立相关链接的程序名

例如查看 8000 端口的情况,使用以下命令:

1
2
# netstat -tunlp | grep 8000
tcp 0 0 0.0.0.0:8000 0.0.0.0:* LISTEN 26993/nodejs

更多命令:

1
2
3
netstat -ntlp   //查看当前所有tcp端口
netstat -ntulp | grep 80 //查看所有80端口使用情况
netstat -ntulp | grep 3306 //查看所有3306端口使用情况

kill

在查到端口占用的进程后,如果你要杀掉对应的进程可以使用 kill 命令:

1
kill -9 PID

如上实例,我们看到 8000 端口对应的 PID 为 26993,使用以下命令杀死进程:

1
kill -9 26993

MySQL 中常用的两种时间储存类型分别是datetimetimestamp。如何在它们之间选择是建表时必要的考虑。下面就谈谈他们的区别和怎么选择。

阅读全文 »