How to run a Java program in a Docker container

作者:Rui 发布时间:September 9, 2015 分类:JAVA,Docker,CLOUD 浏览:625 No Comments

In this post I’m going to show how to create a new Docker image from scratch, how to add the JDK, and how we can use this image to compile and run a Java program.

Creating the Image with the JDK

The first step is to create a new Docker image from the base Docker image ubuntu:14.04 and to install a JDK on top of that. We use a Dockerfile to provide the instructions to build such an image.
There is a link explaining how to Install Oracle Java 8 In Ubuntu Via PPA Repository [JDK8]. Basically we want to execute these commands in a Dockerfile.
The Dockerfile is simply as follows:

RUN apt-get update 
RUN apt-get install software-properties-common -y 
RUN add-apt-repository ppa:webupd8team/java -y 
RUN apt-get update 
RUN echo debconf shared/accepted-oracle-license-v1-1 select true | debconf-set-selections 
RUN apt-get install oracle-java8-installer -y 
RUN apt-get install oracle-java8-set-default 

It’s worth noting that we want the JDK installation to be automated (auto accept license) because the image is built in a not-interactive way and it wouldn’t be possible for us to manually accept the license during the JDK installation. This is done by the debconf-set-selections command. Now we just need to copy the Dockerfile above into a directory (in this article I’m using ~/dockertest) and run the docker build command:

~/dockertest$ docker build -t massimo/javatest:v1 .

阅读剩余部分...

关于融资融券

作者:Rui 发布时间:September 1, 2015 分类:STOCK 浏览:406 No Comments

融资融券是指证券公司向投资者出借资金供其买入证券,或出借证券供其卖出的经营活动。投资者向证券公司借入资金买入证券、借入证券卖出的交易活动,则称为融资融券交易,又称信用交易。

融资融券交易分为融资交易和融券交易两类。投资者向证券公司借入资金买入证券,为融资交易;投资者向证券公司借入证券卖出,为融券交易。

融资可以放大你的操作规模,如当你看好某只股票想大举介入而手中钱又不多时就可以向券商借钱买股票,当股票上涨到目标价后,你可以卖出股票清偿借款,从而放大你的收益。融券为你做空赚钱创造了条件,当你看跌某股时,你可以向券商借入该股,然后将其卖掉,等其下跌后你再买入该股票还给券商,从中获取差额。

简单了说,融资就是券商借钱给你买股票,等你卖出或者时间截至时你在还钱,融券是券商借股票让你卖出,等你在买入该股票或者到期时系统自动买入股票时,偿还借的股票。

阅读剩余部分...

如何在 Ubuntu上配置伪分布式Hadoop

作者:Rui 发布时间:August 28, 2015 分类:JAVA,Linux,BIGDATA 浏览:488 No Comments

环境

  1. Ubuntu 12.04 TLS
  2. Oracle JDK 1.8
  3. Hadoop2.6.4

创建用户并设置SSH

创建用户

sudo useradd -m hadoop -s /bin/bash
sudo passwd hadoop 
sudo adduser hadoop sudo
sudo su - hadoop

SSH Password-less login setting

cd ~/.ssh/                     
ssh-keygen -t rsa             
cat ./id_rsa.pub >> ./authorized_keys  

环境变量设置

解压 Hadoop2.6.4 并将Hadoop-2.6.4 放到 /home/hadoop.

vim ~/.bashrc

在此文件中添加一下变量

export JAVA_HOME=/usr/lib/jvm/java-8-oracle
export HADOOP_HOME=/home/hadoop/hadoop-2.6.4
export PATH=$PATH:$HADOOP_HOME/sbin:$HADOOP_HOME/bin

阅读剩余部分...

编程思想与技术总结

作者:Rui 发布时间:August 5, 2015 分类:JAVA 浏览:432 No Comments

我不是天才,但我相信,通过有效的方法和训练,以及持之以恒地积累,完全是可以成为一名出色的开发者的。那么,到目前为止,掌握了多少思想、方法和技术可以用于开发程序、处理软件开发过程中所遇到的问题呢?不妨作下总结,以备后用。

1. 抽象:
萃取出主要特征,而摒弃次要不相关的特征;无需了解物质的内部实现细节而基于其提供的抽象来构造应用;声明与实现相分离。计算机科学中的抽象俯拾即是,比 如汇编语言是对机器硬件的抽象,编译器是对高级程序语言的抽象,进程是对程序一次执行的抽象,线程是对任务执行流的抽象等。

2. 封装:
由抽象直接引出的重要概念就是封装。函数是算法的良好封装,对象是状态与逻辑的良好封装, 封装是实现软件模块化、提高软件可维护性的重要技术。封装是实现许多软件工程思想的溯源。比如,隔离变化, 将变化的影响局部化等

3. 复用:
不要重复发明轮子。复用是软件工程领域的重要技术。从标准库函数,STL,JDK这样的代码级复用,到 Struts, hibernate 这样的应用框架复用, 以及 设计模式的复用, 解决方案的复用, 复用无处不在。 复用是站在巨人的肩膀上, 能够直接利用专家级的知识和经验,何乐而不为?

4. 分层:
将系统分解为多个层次,精确定义每层所提供的服务及层次之间提供的服务接口;处于某个层次的层依赖于下一层提供的服务,并为上一层提供服务;各层之间无需知道彼此的细节。典型例子是网络协议栈及操作系统虚拟机的概念。

5. 模式:
在《水平思考的力量》一书中谈到,大脑的运作机制主要是模式机制,即通过模式存储、识别、连接和提取来实现思考。生活中无时不刻使用着模式,模式提高了人们的适应能力和反应能力。设计模式是模式思想在软件设计中的运用。

6. 缓存:
将一部分已求解值存储起来以备后用;或者将一次性存储一部分数据(包括但不仅含有当前所需数据),以便之后紧随着访问。动态规划法是使用缓存思想的典型例子。
存储器高速缓存是缓存思想的又一典型例子,与程序局部性原理密切相关。要想达到更好的程序性能,则必须采用一定手段,使得访问数据的顺序与数据在存储器中的存储顺序保持一致,这样才能提高命中率,防止大量的缺页中断带来的低效。

7. 中断:
保存现场, 。。。, 恢复现场。 中断是实现许多计算机制的重要基础。子程序,进程切换, I/0读写…… 思想是简单的, 影响是深远的。

8. 科学原理和性质
深刻理解科学原理和性质,往往能够催生非常简洁高效的算法和技术,这可能就是计算机科学家与开发者之间的一大区别吧。比如向量的旋转问题,将ab转 换为ba, 也是基于对逆置性质的深刻理解上。R(R(a)R(b)) = ba ; 问题: 将 abc 转换为 cba 呢?
向量的旋转问题: http://blog.csdn.net/shuqin1984/article/details/6331772

9. 二分搜索技术:
用于在有序数组(连续物理存储块)中查找给定关键字,时间复杂度为O(logn)。
例子: 在有序数组里找出给定关键字出现的次数;在不重复的若干整数中找出不存在的整数; 程序调试技巧。

10. 分区技术:
给定一个列表,从中选定一个主轴元素,将它置于某个位置,并将列表中的元素分为两个部分:使前半部分的所有元素都不大于该元素,后半部分的元素都不 小于该元素。例子:快速排序,找出第k大的元素(顺序统计量),请参阅《算法导论》第7章(快速排序)和第9章(顺序统计量)。

阅读剩余部分...

Lex&Yacc Compiler

作者:Rui 发布时间:August 5, 2015 分类: 浏览:506 No Comments

This is a simple example to show how to use Lex/Yacc to generate IA32 code

Operating Environment

  • OS X 10.9.2
  • Lex, Bison, Gcc

Program Grammar

Variable Type

s : String <- "abcd";
x : Int;
x : Int []; 

Variable Declaration

y : Int ;
x : Int -> 1;

Assignment Statement

x -> 1;

If Statement

if 
    a < 2 
then 
    1 
else 
    factorial(a-1) + factorial(a-2)
fi

阅读剩余部分...