如何零成本搭建一个远程随时可用的服务器

如何零成本搭建一个远程随时可用的服务器

make-your-computer-accessible-to-internet

让你的电脑能够随时通过互联网访问,包括DDNS服务,路由器设置,公网IP查询技术和IP域名动态绑定

最近组装了一台2手电脑,放在家里,有时希望能在外面通过ssh 连进家里的服务器

家庭办理的是电信宽带,100M光纤入户,打了10000号申请静态公网IP,反馈说不行,静态公网IP需要申请企业专线套餐,目前网络状态是动态公网IP(隔一段时间,IP就会进行变更)

所以思路是,在服务器上,写一段定时脚本,定时上报自己的IP地址到DNS服务商,DNS服务商更新DNS中的ip,然后通过域名进行访问。

不过首先要解决的是,如何从通过路由器定位到机器


IntelliJ IDEA 插件,提高生产效率

IntelliJ IDEA 高效率插件

IntelliJ 在业界被公认为最好的 java 开发工具之一,尤其在智能代码助手、代码自动提示、重构、CVS 整合、代码审查、 创新的 GUI 设计等方面的功能可以说是超常的

分享一些 java开发常用 IntelliJ 插件

1. Alibaba Java Coding Guidelines(P3C)

项目地址
https://plugins.jetbrains.com/plugin/10046-alibaba-java-coding-guidelines
https://github.com/alibaba/p3c/tree/master/idea-plugin

阿里巴巴出品的 java 代码规范插件,可以扫描整个项目,找到不规范的地方,并且大部分可以自动修复。

具体介绍和安装 见 https://github.com/alibaba/p3c/tree/master/idea-plugin

2.FindBugs-IDEA

项目地址
https://plugins.jetbrains.com/plugin/3847-findbugs-idea

检测代码中可能的 bug 及不规范的位置,检测的模式相比 p3c 更多,写完代码后检测下,避免低级 bug,强烈建议用一下,一不小心就发现很多老代码的 bug。

3. GsonFormat

地址
https://plugins.jetbrains.com/plugin/7654-gsonformat

一键根据 json 文本生成 java 类,非常方便。

4. Maven Helper

地址
https://plugins.jetbrains.com/plugin/7179-maven-helper

一键查看 maven 依赖,查看冲突的依赖,一键进行 exclude 依赖,对于大型项目非常方便

5. VisualVM Launcher

地址
https://plugins.jetbrains.com/plugin/7115-visualvm-launcher

运行 java 程序的时候启动 visualvm,方便查看 jvm 的情况 比如堆内存大小的分配,某个对象占用了多大的内存,jvm 调优必备工具。

6.Rainbow Brackets

彩虹颜色的括号,看着很舒服,敲代码效率变高。

7.Free Mybatis plugin

Mybatis的mapper接口和xml配置文件之间相互导航.

8.JRebel

本地服务器起来后,修改了类或者配置文件热加载,不用重启服务器.(此插件为收费插件,下面附破解教程)

https://blog.csdn.net/qq_27093465/article/details/79148498

java编程技巧累积(持续更新)

java 编程技巧累积

  1. 对象深复制
  2. ShutdownHook
  3. LRUMAP
  4. 单例模式
  5. Mysql insert/update IGNORE的利用
  6. 更多…

Hbase Shell 常用命令

HBase是一个分布式的、面向列的开源数据库

Apache HBase是一种Key/Value系统,它运行在HDFS之上。和Hive不一样,Hbase的能够在它的数据库上实时运行,而不是运行MapReduce任务。Hbase被分区为表格,表格又被进一步分割为列簇。列簇必须使用schema定义,列簇将某一类型列集合起来(列不要求schema定义),每一个 key/value对在Hbase中被定义为一个cell,每一个key由row-key,列簇、列和时间戳。在Hbase中,行是key/value映射的集合,这个映射通过row-key来唯一标识。Hbase利用Hadoop的基础设施,可以利用通用的设备进行水平的扩展。

Hive是一种类SQL的引擎,并且运行MapReduce任务。Hive适合用来对一段时间内的数据进行分析查询
Hbase是一种在Hadoop之上的NoSQL 的Key/vale数据库。Hbase非常适合用来进行大数据的实时查询

HBase shell是HBase的一套命令行工具,类似传统数据中的sql概念,可以使用shell命令来查询HBase中数据的详细情况。安装完HBase之后,如果配置了HBase的环境变量,只要在shell中执行hbase shell就可以进入命令行界面


MySQL整体逻辑架构

MySQL 整体逻辑架构

非原创-记录下

包括

  • MySQL整体逻辑架构
  • 查询执行流程
  • SQL解析顺序

MySQL整体逻辑架构(MySQL`s Logical Architecture)

![MySQL`s Logical Architecture](./images/mysql/logic1.jpg)


Ambari 插件开发笔记

Ambari插件开发

Apache Ambari项目旨在通过开发用于配置,管理和监控Apache Hadoop集群的软件,使Hadoop管理更简单。Ambari提供了一个直观的,易于使用的Hadoop管理Web UI,由其RESTful API支持。但有时候有一些自定义非官方的需求,这时就需要基于ambari做二次开发了。

Ambari是支持服务扩展的,只需要,编写自定义服务相关配置、脚本,然后扔到它的资源目录,重启服务器就可以了。听起来很简单。它的服务组织结构是分Stack / Service /Component 3层的 。

开发的一个java 服务插件定义目录结构

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
[daxiang@ark1 common-services]$ pwd
/var/lib/ambari-server/resources/common-services
[daxiang@ark1 common-services]$ tree ARK_DATA_API/
ARK_DATA_API/
└── 0.0.1
├── alerts.json
├── configuration
│   ├── ark-data-api-env.xml
│   └── ark-data-api-server.xml
├── metainfo.xml
└── package
├── archive.zip
├── scripts
│   ├── ark_app_api.py
│   ├── params.py
│   └── status_params.py
└── templates
└── application.properties.j2

5 directories, 9 files

Ambari 简介和安装笔记

ambari 介绍

Ambari 跟 Hadoop 等开源软件一样,也是 Apache Software Foundation 中的一个项目,并且是顶级项目

就 Ambari 的作用来说,就是创建、管理、监视 Hadoop 的集群,但是这里的 Hadoop 是广义,指的是 Hadoop 整个生态圈(例如 Hive,Hbase,Sqoop,Zookeeper 等),而并不仅是特指 Hadoop。用一句话来说,Ambari 就是为了让 Hadoop 以及相关的大数据软件更容易使用的一个工具。

接下来进行一次简单的安装,算是一次安装笔记

  1. 下载准备好ambari 和hdp 系列安装包的本地yum源
  2. 安装ambari
  3. 如何通过ambari安装HDP等服务

Your browser is out-of-date!

Update your browser to view this website correctly. Update my browser now

×