'IT'에 해당되는 글 31건

  1. 2024.09.19 vsftpd를 sftp로 바꿔서 설정하기
  2. 2024.09.04 vsftpd for CentOS7
  3. 2020.07.29 CSRF, JWT 토큰
  4. 2017.12.30 랜섬웨어 감염시
  5. 2017.11.28 Web Service-SOAP
  6. 2017.10.30 microService의 장단점
  7. 2017.08.28 IP로 country판별
  8. 2017.07.19 prmd
  9. 2017.07.05 kotlin
  10. 2017.06.13 docker
  11. 2017.03.16 MEAN, LAMP & Others
  12. 2016.10.11 구글 SLAM 공개
  13. 2016.08.16 Message Digest
  14. 2016.08.15 HTTP 2.0
  15. 2016.08.10 유니코드
  16. 2016.08.01 OSI 7 Layer
  17. 2016.05.28 XML XSD와 DTD와 차이.
  18. 2016.01.20 GPL vs LGPL
  19. 2015.10.01 Git
  20. 2015.09.30 SOAP
  21. 2015.09.11 Oracle Index, HashJoin, 메모리
  22. 2015.09.10 chrome - mobile mode
  23. 2015.08.12 Frontend hacking
  24. 2015.07.29 UML & GoF pattern
  25. 2015.03.27 Scrum
  26. 2015.03.12 자동화 테스트 툴
  27. 2014.09.29 SW Engineering
  28. 2014.07.31 사설 IP 대역
  29. 2008.01.16 OpenAPI, REST방식
  30. 2007.11.16 MCE 기능들

추가: ssh는 기존 pem파일 로그인, sftp는 비번 로그인으로 설정하는 법. /etc/ssh/sshd_config 파일 에 추가. 

# 공개 키 인증을 기본으로 사용
PasswordAuthentication no
PubkeyAuthentication yes

# SFTP만 비밀번호로 허용
Match Group sftpusers  (이건 맞는 그룹으로 변경필요) 
    PasswordAuthentication yes
    PubkeyAuthentication no
    ForceCommand internal-sftp

$sudo systemctl restart sshd

 

 

SFTP(Secure File Transfer Protocol)를 사용하기 위해서는 현재 설정된 vsftpd를 변경할 필요는 없습니다. SFTP는 SSH(Secure Shell) 서비스로 작동하기 때문입니다. CentOS 7에서 SFTP를 사용하도록 설정하는 방법은 다음과 같습니다:

1. SSH 설치 및 실행 확인

SFTP는 SSH를 통해 작동하므로, SSH 서버(sshd)가 설치되고 실행 중인지 확인해야 합니다.

 
sudo yum install openssh-server sudo systemctl start sshd sudo systemctl enable sshd

2. SFTP 사용자 설정

이미 cncity라는 사용자가 있습니다. 이 사용자가 유효한 쉘(예: /bin/bash)을 가지고 있고 올바른 홈 디렉토리를 가지고 있는지 확인합니다:

bash
 
sudo usermod -s /bin/bash cncity

사용자의 홈 디렉토리가 존재하고 올바른 권한을 가지고 있는지 확인하세요:

bash
 
sudo mkdir -p /home/centos/nfs/cncity sudo chown cncity:cncity /home/centos/nfs/cncity

3. SFTP만 허용하도록 사용자 제한 (선택 사항)

만약 SFTP만 허용하고 전체 SSH 접근을 제한하려면, SFTP를 위한 제한된 쉘을 설정할 수 있습니다:

SSH 설정 파일 편집:

bash
코드 복사
sudo vi /etc/ssh/sshd_config
cncity 사용자에 대한 SFTP 제한 설정 추가:

plaintext
코드 복사
Match User cncity
    ForceCommand internal-sftp
    ChrootDirectory /home/centos/nfs
    PermitTunnel no
    AllowAgentForwarding no
    AllowTcpForwarding no
    X11Forwarding no
ForceCommand internal-sftp는 사용자가 SFTP만 사용하도록 강제합니다.
ChrootDirectory /home/centos/nfs는 사용자를 지정된 디렉토리(/home/centos/nfs)로만 제한합니다.
ChrootDirectory는 root가 소유하고 사용자에게 쓰기 권한이 없어야 합니다.
Chroot 디렉토리의 권한 설정:

bash
코드 복사
sudo chown root:root /home/centos/nfs
sudo chmod 755 /home/centos/nfs
SSH 서비스 재시작:

bash
코드 복사
sudo systemctl restart sshd

 

 

4. 기본적으로는 id/비번만으로 동작함. but 키 인증기반으로 변경할 수도 있음.

1. 기본 설정 (암호 인증)
클라이언트에게 제공할 것: 사용자 이름과 비밀번호
설명: SFTP 접속 시 클라이언트는 서버의 IP 주소, 사용자 이름, 비밀번호만으로 접속할 수 있습니다. 추가적인 인증 키나 인증서는 필요하지 않습니다.
보안 수준: 기본적인 암호 인증은 충분히 안전하지만, 키 기반 인증보다 상대적으로 보안이 낮을 수 있습니다.
2. 키 기반 인증 (더 안전한 방법)
클라이언트에게 제공할 것: 개인 SSH 키 (Private Key)

설정 방법:

서버에서 SSH 키 쌍을 생성 (클라이언트가 생성할 수도 있음):

bash
코드 복사
ssh-keygen -t rsa -b 2048
이 명령을 실행하면 id_rsa(개인 키)와 id_rsa.pub(공개 키)라는 두 개의 파일이 생성됩니다.

클라이언트의 공개 키를 서버에 복사:

공개 키 파일(id_rsa.pub)을 서버의 사용자의 홈 디렉토리에 있는 ~/.ssh/authorized_keys 파일에 추가합니다:

bash
코드 복사
cat id_rsa.pub >> /home/cncity/.ssh/authorized_keys
SSH 설정 파일에서 키 인증 사용 (이미 기본적으로 활성화되어 있을 수 있음):

/etc/ssh/sshd_config 파일을 열고 PubkeyAuthentication이 yes로 설정되어 있는지 확인합니다:

plaintext
코드 복사
PubkeyAuthentication yes
SSH 서비스 재시작:

bash
코드 복사
sudo systemctl restart sshd
클라이언트 측: 클라이언트는 개인 키(id_rsa)를 SFTP 접속 시 사용해야 합니다. SFTP 클라이언트에서 개인 키를 설정하거나, 명령줄에서 다음과 같이 사용할 수 있습니다:

bash
코드 복사
sftp -i /path/to/private_key cncity@your_server_ip
보안 수준: 키 기반 인증은 암호 기반 인증보다 안전합니다. 개인 키를 분실하지 않도록 주의해야 하며, 개인 키는 암호로 보호하는 것이 좋습니다.
Posted by yongary
,

vsftpd for CentOS7

IT 2024. 9. 4. 16:44

기본 설치 방법.

sudo yum install vsftpd

sudo systemctl start vsftpd
sudo systemctl enable vsftpd

 

 

 

sudo vi /etc/vsftpd/vsftpd.conf 기본설정 항목. 

# 익명 사용자 접속 금지
anonymous_enable=NO

# 로컬 사용자 접속 허용
local_enable=YES

# 업로드 권한 부여
write_enable=YES

# 사용자 홈 디렉토리를 루트 디렉토리로 설정
chroot_local_user=YES

# FTP에 허용할 사용자 목록을 지정하는 설정
userlist_enable=YES
userlist_file=/etc/vsftpd/user_list
userlist_deny=NO

 

sudo vi /etc/vsftpd/user_list 에는
cncity
라는 유저명 한줄만 있으면 됨. 

 

 

 

FTP 루트 디렉토리를 홈 디렉토리로 설정하는 chroot_local_user=YES가 이미 활성화된지 확인합니다. 이 설정은 사용자가 자신의 홈 디렉토리(지금은 /home/centos/nfs/cncity)로만 접근하도록 제한하는 역할을 합니다.

$sudo vi /etc/vsftpd/vsftpd.conf

# 로컬 사용자 홈 디렉토리를 루트 디렉토리로 설정
chroot_local_user=YES

# 일부 사용자만 chroot 제한을 적용하려면
# chroot_list_enable=YES
# chroot_list_file=/etc/vsftpd/chroot_list
Posted by yongary
,

CSRF, JWT 토큰

IT 2020. 7. 29. 15:09

csrf 는 웹서비스에서 cross-site-request-forgery를 막기위해

백엔드에서 토큰을 발행하고 프론트엔드에서 이를 사용하여 최종적으로는 유효한 요청인지를 확인하는 방식.

 

 

JWT토큰은 인증에 사용되는 방식으로서 REF

OAuth와 연동해서 사용할 수도 있고 독립적으로 사용할 수도 있다.

 

 OAuth1과 OAuth2의 가장 큰 차이는 OAuth2의 경우 refresh 토큰이 가능. 

 

 

 

JWT를 구현하면서 마주치게 되는 고민들

최근 모바일, 웹 등 다양한 환경에서 서버와 통신하면서 많은 사람들이 JWT 토큰 인증 방식을 추천합니다. 이 포스팅에서는 JWT를 이해하고 구현하면서 마주치게 되는 고민들에 대해 정리해보려 �

swalloow.github.io

 

Posted by yongary
,

랜섬웨어 감염시

IT 2017. 12. 30. 10:22

랜섬웨어에 감염되어 파일들이 확장자가 변경되면서 실행이 안된다면..


1. windows/system32/tasks  밑에 가서, 날짜를 보고 최근 것들을 지운다.

  => 랜섬웨어 동작을 멈추게 한다.

  (그 후 고클린 등으로 각종 clear작업을 해주면 더 좋다)


2. 이미 감염된 파일들은 복구가 불가능 한데, 

   https://www.nomoreransom.org/ko/index.html   여기에 가면 일부 복구가 되는 랜섬들이 나열되어 있으므로

   따라서 복구를 한다.

Posted by yongary
,

Web Service-SOAP

IT 2017. 11. 28. 09:40

요즘은 REST가 대세이긴 하지만,

SOAP도 나름대로의 장점이 있다. 이 기종간 명확한 spec기반의 통신이 가능하다.


SOAP을 위해서, WSDL을 먼저 생성하는 게 좋은데

eclipse나 IDEA에서도 생성이 가능하지만


oXygen XML 에디터가 좋아보인다.



생성된 WSDL기반으로 테스트 하기에는 SOAP UI라는 툴이 좋아 보인다.  REF

다운로드는 https://www.soapui.org/  에서 Download로 들어가면 SoapUI OpenSource가 있다. 

Posted by yongary
,

microService의 장단점

IT 2017. 10. 30. 22:25

REF


서비스를 잘게 쪼개서 별도의 서비스들로 만들고

서비스들간에 REST등의 방식으로 통신을 하게 하는 방식인데


이로인한, 장단점이 명확하다.



Posted by yongary
,

IP로 country판별

IT 2017. 8. 28. 10:27

 MaxMind의 Geolocation DB를 이용하면 된다.

GeoIP2-Country DB를 이용하는 게 좋고,  DB의 path를 "GeoIP2-Country.mmdb" 로 잡는다. REF

Posted by yongary
,

prmd

IT 2017. 7. 19. 17:18

JSON이나 yml파일들을 이용해 자동으로 document생성.  REF


$prmd combine --meta meta.yml schema | \

  

Posted by yongary
,

kotlin

IT 2017. 7. 5. 19:58

android를 대신하기 위해, 정확하게는 android안의 java를 대신하기 위해 만들어졌다는 kotlin..



주요 특징은 다음과 같다.


 - 변수선언시   var, val (immutable) - 많은 부분이 scala에서 왔다.

 - null safe : 심지어는 컴파일 에러가 난다.


 - javascript를 섞어쓸수 있다 : 이때 장점은 잘 모르겠는데 WEB개발에 유리하지 않을까 예상되네요.

   (당연히 node.js와도 섞어서 서버에도 사용가능함)  


 - kotlin + springBoot로 웹앱이 개발 가능하다.

   물론  Mockito를 결합해 unit테스트 가능.
      (단, 일반 class는 final개념이라 open class를 써야 함, when은 키워드라 `when`써야함)


- android폰 개발시에는 Glide등 편리한 Extension이 많다.

- Anko를 함께 사용하면 xml을 사용하지 않아도 된다.   (AnkoComponent의 subclass를 사용),  

   AnKo=Android+Kotlin의 의미로 android용  DSL (Domain-Specific Language)임.


- 기타문법  : is ,  ?    (instanceof, ?는 null대비)

      let은 다소 어려움.


  

 

Posted by yongary
,

docker

IT 2017. 6. 13. 17:05

REF:slideshare


Docker는 이미지 파일과 linux프로세서 형태로 실행하는 container로 이루어져있다.

immutable 이미지를 이용하기 때문에, 가상화머신보다 설정과 배포가 용이하다.


이미지와 이미지의 차이만 diff로 관리하기 때문에, github처럼 dockerhub에서 이미지 관리가 가능하다.


그리고 

boot2docker는 가상머신안에 docker를 실행하는 것이라서, host ip로  nginx등의 웹서버에 바로 접속할 수 없다.


이 때, ip를 알 고 싶으면 boot2docker ip를 이용하면 된다.

참고로 boot2docker up 으로 실행을 한다.



Posted by yongary
,

MEAN, LAMP & Others

IT 2017. 3. 16. 18:30

LAMP stack: Linux, Apache, MySql, PHP (Perl/Python)

  REF

MEAN stack: MongoDB, ExpressJS, AngularJS, NodeJS

         - ExpressJS:  Node.js Web application framework. 

         - NodeJS: event-driven I/O server-side JavaScript Environment.




Play-framework :  Scala & java 용 프레임워크.  REF

- 이게 spring처럼 널리 이용된다면 scala도 그만큼 역량을 키워가겠네요.  

- JSON과 xml을 First-class 고객으로 모시는 프레임워크인만큼 계속 영향력이 커지지 않을까요..










Posted by yongary
,

구글 SLAM 공개

IT 2016. 10. 11. 13:39

구굴이 SLAM(Simultaneous Localization and Mapping)용

오픈소스 지도기술 Cartographer를 공개하였다.



SLAM: 로봇이 위치를 인식해서 즉석해서 지도를 작성.

- 무인자동차, 로봇청소기, 드론등에서 활용



이제 일반인도 드론이나 로봇청소기 제작시 본 API를 활용해

야외나 실내의 맵을 실시간으로 만들어 

로봇의 탐색경로를 쉽게 최적화할 수 있을 것으로 보인다.



참고사이트: http://www.bloter.net/archives/265140

시연영상: https://youtu.be/DM0dpHLhtX0 

Cartographer GitHub: https://github.com/googlecartographer 

                  소개: https://opensource.googleblog.com/2016/10/introducing-cartographer.html 





Posted by yongary
,

Message Digest

IT 2016. 8. 16. 17:08

Message Digest는 간단히 말하면 Message Hashing이다.

- 단방향으로만 동작하고 역방향 유추는 불가.

- 암호 저장, file이 동일한 파일인지 비교하는데 쓰인다.

 

Java Ref - java.security.MessageDigest 존재.

 

 

좀 더 복잡하게 하기 위해서  Ref

Salting- 메시지 앞에 특수값을 삽입. (사용자별로 다르게 할 수도 있음)

Key Stretching-  Digest하고 그 값을 또 Digest하는 multi-chain형태의 Digest.

=> 위 둘을 잘 섞어서 Adaptive Key Derivation Functions 이라고 부른다.

대표적인 게 PBKDF2랑 bcrypt, scrypt가 있다.

이 존재한다.

 

 

Posted by yongary
,

HTTP 2.0

IT 2016. 8. 15. 16:54

REFwiki

 

HTTP1.1이 현재까진 대세인데

HTTP2.0은 2015년 5월에 spec이 발표되었고, 대부분의 브라우저에서 2015년 말부터 지원한다.

  - web site들은 10%미만이 이를 지원.

 

주요 특징.

 - HTTP2.0 서버 Push

: 기존에는 index.html을 파싱하고 나사 style.css, javascript.js를 받지만, HTTP 2.0에서는 서버가 index.html 을 내려주면서 같이 css와 js도 내려줄 수 있다.

 

 - HTTPS over TLS

:원래 https는 SSL기반인데,   2.0에서는 https가  TLS기반(SSL의 브랜치)으로 동작한다.

 

 (SSL vs TLS: REF1,  )

-같은 말이다. 네스케이프에 의해서 SSL이 발명되었고, 이것이 점차 폭넓게 사용되다가 표준화 기구인 IETF의 관리로 변경되면서 TLS라는 이름으로 바뀌었다. TLS 1.0은 SSL 3.0을 계승한다. 하지만 TLS라는 이름보다 SSL이라는 이름이 훨씬 많이 사용되고 있다.

( REF2-의심감)

 SSL - 7.Application Layer 와 4.Transport Layer 간에서의 보안.

 TLS -  서버인증은 선택사항, 반드시 공개키만 사용.

 

 - SPDY (pronounced like "speedy") : TCP pipe는 쓰면서도 TCP와 다른프로토콜을 사용하는데 HTTP2.0 초기에는 SPDY방식으로 HTTP가 바뀔 것으로 제안 되다가 몇가지 문제가 있어 빠진 것으로 보임.

 

Posted by yongary
,

유니코드

IT 2016. 8. 10. 18:02

<UnicCode> REFWiki  REF2

UTF 8  - 가변길이의 유니코드이다.   ASCII영역은 1Byte로 표현되고, 일반적으론 한글은 3Byte로 표현된다.. 드물게 4byte로 표현되는 언어도 있다.

 

UTF 16 - ASCII영역도 2Byte로 표현된다.

 

 

<다른 encoding>


EUC-KR (MS의 CP949는 EUC-KR을 확장) :  한글OS에서만 제대로 보이는 문제 존재. 영문-1Byte, 한글-2Byte 로 고정Length

Posted by yongary
,

OSI 7 Layer

IT 2016. 8. 1. 15:47

OSI 7계층을 아주 간단히 정리하면 다음과 같다.

REF

 

7: Application Layer (응용 계층)

- 텔넷 등

 

6: Presentation Layer

- Encoding/Decoding 압축/암호화 등이 이루어지는 Layer이다.

 

5: Session Layer

- 운용 체제에서 다루어주는 TCP/IP 세션 생성 및 해제.

 

4: Transport Layer(트랜스포트 계층)

- 쉽게 TCP를 이용하는 계층이라고 보면 된다.

- End-to-End간 통신을 다루는 최하위 계층이다.

- 오류검출, 흐름제어, 중복검사 등이 이루어진다.

 

3: Network Layer

- IP와 라우팅 기반으로 데이타 통신이 이루어진다.

- 패킷 생성이 이루어지며, QoS관리 등이 이루어진다.

 

2: Data Link Layer (데이터 링크 계층)

- MAC Address 기반으로 통신을 하는 계층.

- CRC 체크등 에러체크 가 이루어 진다.  (+재전송/흐름제어)

 

1: Physical Layer(물리계층)

- H/W Layer로서 가장 복잡한 계층이다.

Posted by yongary
,

XML XSD와 DTD와 차이.

IT 2016. 5. 28. 10:15

참고사이트: http://www.scitech.co.kr/upload/book_image/s_017/Xml04.pdf 


<DTD>


 <!DOCTYPE Memo [

    <!ELEMENT Memo (PInfo, MInfo)>

    <!ELEMENT PInfo (from, to)>

    <!ELEMENT MInfo (date, main)>

    <!ELEMENT form (#PCDATA)>

    <!ELEMENT to (#PCDATA)>

    <!ELEMENT date (#PCDATA)>

    <!ELEMENT main (#PCDATA)>

]>



     DTD를 이용한 XML:  REF사이트



<XML XSD> : XML Schema Definition.


<?xml version="1.0" encoding="EUC-KR"?>

<xsd:schema xmlns:xsd="http://www.w3.org/2001/XMLSchema"

targetNamespace="http://www.lisia.net"

xmlns="http://www.lisia.net"

elementFormDefault="qualified">


<xsd:element name="Memo">

 <xsd:complexType>  

  <xsd:sequence>

    <xsd:element name="PInfo">

    <xsd:complexType>

     <xsd:sequence>

       <xsd:element name="from type="xsd:string"/>

       <xsd:element name="to" type="xsd:string"/>

   </xsd:sequence>




==> XSD 를 이용한  XML   

 

<?xml version="1.0" encoding="EUC-KR"?>

<Memo xmlns="http://www.lisia.net" 

              xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 

              xsi:schemaLocation="http://www.lisia.net ex4_3.xsd"> 

<PInfo>

     <from>김광수</from>

     <to>박수란</to>

</PInfo>

   

Posted by yongary
,

GPL vs LGPL

IT 2016. 1. 20. 16:43

GPL (General Public License) source를 사용하거나 binary를 사용하더라도 본인의 프로그램을 오픈해야함
LGPL (Lesser GPL) :  source를 사용하면 오픈, Library형태의 binary를 사용하면 오픈안해도됨  REF-SITE

 

BSD: 무제한 사용.

Posted by yongary
,

Git

IT 2015. 10. 1. 11:27

SVN의 단점을 극복한 Git, 리누스 토발즈가 만들어서 더욱 유명하다.

특히 github.com 서버에서 git을 이용한 무료소스관리를 해주므로 무수한 사용자들이 사용하고 있다.

 

개인적으로 느낀 git의 가장 큰 장점은

local 커밋이 가능하다는 점이다. 즉 비행기를 타고 가는 중에도 커밋이 가능하다.

 

개발자로서 자주 커밋하는 것이 안전하다는 것을 항상 느끼는데,

수십명이 사용하는 서버에 한줄 고치고 커밋하는 걸 여러번 하면 형상관리가 지저분해지는 단점이 있었는데

git을 이용하면 로컬 커밋을 자주하다가, 서버에는 push로 올리면 된다.

 

 

 

http://git-scm.com/book/ko : 공식매뉴얼




Git 기본 사용법 :

  git config --list

 

  git config --global use.name "myName"

  git config --global user.email my@Email

  git config --global core.editor vim

  git config --global merge.tool vimdiff

 

  git init

  git add <a.c>

  git commit -m 'test'

git remote add origin gitURL(like github)

  git push -u origin master

 

 

 

Windows용 git도 있다.  http://www.git-scm.com/downloads  에서 다운로드 가능.

 

설치해서 icon만 고르면,  minGW의 bash쉘에서 git이 실행이 된다.
(컴퓨터 이름이 한글일때 prompt가 깨지는 현상이 있음:  Administrator@ㅁㅁㅁ ~$  이렇게 되네요)

 

 

tip: 한글설정: git config --global core.quotepath false

이쁘게: .bashrc에 alias ls='ls -al --color=auto --show-conftrol-chars'

 

Posted by yongary
,

SOAP

IT 2015. 9. 30. 13:47

REST가 대세이긴 하지만, 이전 시스템들을 위해 SOAP을 알아둘 필요가 있다.

REF-SITE



SOAP(Simple Object Access Protocol)은 HTTP/SMTP 상에서 XML기반 메시지를 교환하는 프로토콜 이다.


SOAP에서는 SOAP Envelope과 SOAP BODY 를 주로 이용한다.

   -> SOAP BODY에   <Price>$4.0</Price> 와 같이 전달.



SOAP외에,  WSDL 로 웹서비스가 정의 되기 때문에 WSDL 을 이해하여야 한다.



WSDL(Web Services Description Language)

   <portType>의  <operation>  메서드 선언 </operation>   : What 정의

    <service>의   <port> 웹서비스 URL </port>   : How&Where  즉 서비스의 EndPoint 정의.



그리고 실제 구현하면서 JAXB 와 같이 JAVA <-> XML 마샬링 툴등을 이용하게 된다.





JSON이 대세인데,  SOAP을 보고 있으니 답답하다는 생각이 들긴한다.

mongoDB + Angular.js 를 이용해 JSON 을 이용해서 REST방식으로 구현하길 권장한다.



Posted by yongary
,

Index

 - Primary키는 자동으로 인덱스로 생성된다.

 - 나머지 index는 생성해야 하는데,
     index는  Unique해도 되고 Unique하지 않아도 된다.

 

 

오라클 메모리 :

   PGA - 정령공간, 세션정보, 커서정보, 변수저장

   SGA - 공유풀, 데이터버퍼케쉬, ReDo Log버퍼

     -SGA조절 파라미터  : 10g부터는 자동조절 기능 제공.
            shared_pool_size        

db_cache_size
 log_buffer

 

Join ==========================Join===============

RDBMS에 일반적으로 많이 사용하는 NL(Nested Loop)조인 외에,

오라클에는 Hash Join이 존재한다.

 

((조인의 종류))

1. Sort Merge 조인  (양쪽을 sort해서 join한다..)

   - 잘 안쓰는 것 같은데.. 잘 못봤음

     (주로 Ordered 테이블에서 유리하지 않을까 예상 됨)

 

2. NL(Nested Loop)조인

  - 일반적인 조인.

   이너조인이 일반적이며, 아우터조인도 있음

 

3. 오라클 Hash Join

- (다른 RDMBS에도 있는지 좀 찾아봐야 하지만..)
  A. 작은 테이블(Build Input)을 읽어 Hash Area에 해시 테이블 생성한다.
    (해시 함수에서 리턴 받은 버킷 주소로 찾아가 해시 체인에 엔트리를 연결)
  B. 큰테이블 집합(Probe Input)을 읽어 해시 테이블을 탐색하면서 조인하는 방식이다.
    (해시 함수에서 리턴 받은 버킷 주소로 찾아가 해시 체인을 스캔하면서 데이터를 찾는다)

 

   기준테이블(작은 테이블:build Input)이 충분히 작은 경우에 Hash Join이 적합하다.


 

Posted by yongary
,

chrome - mobile mode

IT 2015. 9. 10. 08:44

In chrome - F12 is Debug mode



On left-top corner,  find and click 

toggle device mode icon off : toggle Device mode 



then you can resize your screen .  (default is small phone)

Initial start for device mode

Posted by yongary
,

Frontend hacking

IT 2015. 8. 12. 23:56

SQL Injection

XSS (Cross Site Scripting) - javascirpt를 입력.  


==> 해결책: escapeHtml, escapeScirpt 등을 사용하거나, MVC framework을 사용. angular.js도 어느정도 막을 수 있을 듯.



그외,  

Command Injection

XXE(XML External Entity) 

등의 해킹법도 있음.

Posted by yongary
,

UML & GoF pattern

IT 2015. 7. 29. 22:53

<UML>  Reference Site:


 Inheritance:       ㅡㅡㅡㅡㅡD        


 Interface:          - - - - - - D


 association(has):   A  ㅡㅡㅡㅡㅡ>     B               class A { member B}   

                                  Leg  <.>----->  필수.

           Flea <>------>



 dependency:             A  - - - - - >     B                 class A uses B temporary.




<Gof Pattern> Reference SIte

Creational Pattern:  Singleton, (Abstract)Factory, Builder, Prototype

Structral Pattern: Adapter, Decorator, Bridge, Proxy

Behavior Pattern: Command, Iterator, Visitor, Observer, Chain of Responsibility



Posted by yongary
,

Scrum

IT 2015. 3. 27. 17:21


위키kr :  Scrum(애자일 개발 프로세스)


- 매일15분씩 회의. (어제한일, 오늘한일, 장애상황)


- 스프린트 (한 주기) 관리  ( 30일 +- 1~4주)


- Sprint backlog

  다음 Sprint의 backlog도 미리 준비한다.



==========링크내용===================================

제품 책임자(Product Owner) 
제품 백 로그를 정의하여 우선순위를 정해 준다.

스크럼 마스터(ScrumMaster) 
프로젝트 관리자(코치)

스크럼 마스터는, 일반적인 관리를 수행하는 프로젝트 관리자들과는 달리 팀원을 코칭하고 프로젝트의 문제 상황을 해결하는 역할을 하며, 제품 책임자는 스프린트 목표와 백로그등의 결정에 있어 중심이 되는 상위 관리자로, 제품 책임자가 독단적으로 목표를 결정하지 않고, 고객과 관리자 및 팀원들이 모여서 목표를 정한다.

이런 과정을 거친 뒤, 개발 팀원들이 주도적으로 스프린트 목표를 달성하기 위한 작업을 정해 나가게 된다. 보통, 각 작업들은 4시간에서 16시간 정도 걸리도록 정한다. 물론, 작업을 정하고 할당하는데는 고객이나 제품 책임자와는 상관 없이 팀원 자율로 진행된다. 이와 같은 자율적인 행위를 통해서 팀원들은 의사를 활발하게 주고 받게 되고, 끈끈한 협업체계를 가지게 된다.

Posted by yongary
,

자동화 테스트 툴

IT 2015. 3. 12. 09:20

TDD : Test Driven Development

=> 웹 자동화 테스트툴- Sellinium.



BDD: Behavior Driven Development

=> Cucumber.

Posted by yongary
,

SW Engineering

IT 2014. 9. 29. 08:54

소프트웨어 공학의 최근 흐름으로는 관점 지향(Aspect), 애자일(Agile), 모델 주도(Model-Driven) 등이 있다.



Agile 방법론의 기본 개념 "반복적으로 프로토 타입을 고객에 전달함으로써 고객의 요구사항 변화에 민첩하게 대응한다"


Agile 방법론의 대표주자XP(익스트림 프로그래밍) 




XP(익스트림 프로그래밍) 개발 프로세스 :


XP의 목적은 '고객이 원하는 양질의 소프트웨어를 빠른 시간안에 전달하는 것'이다. 
수시로 발생하는 고객의 요구사항에 대처하고, 고객이 원하는 SW를 고객이 원하는 시간에 인도하기 위해서는 고객과 팀원간의 대화를 통해 해결한다.


XP에는 7가지 항목이 정의되어 있는데, 7가지 항목 중 특히 공감이 가는 항목은 아래와 같이 4항목이다.

1.Simple-Design

2.Test-Driven

Test_driven은 다른 애자일 방법론과 구분되는 XP만의 특징이기도 하다.

프로그래머들이 코딩을 할 때에, 테스트 코드를 작성하도록 함과 동시에 테스트를 기반으로 프로젝트를 완성시켜 나간다.

3. Pair-Prograimming 

두명 혹은 그 이상의 프로그래머가 함께 코딩을 하는 것을 말한다. 두명의 프로그래머가 함께 코딩을 하고 테스트를 통해서 개발을 할 수도 있고, 한명은 코딩을 하고 한명은 Quality Assurance 역할 통해서 테스트에만 집중을 할 수도 있다.

4. Whole-Team 

기획자, 설계자 심지어는 Tester, User까지도 하나의 팀이 되어 개발을 진행하는 방법이다.


나머지 3항목은 

Planning Game, Small Release, Customer Test이다.








Posted by yongary
,

사설 IP 대역

IT 2014. 7. 31. 09:38

사설 IP 대역은 아래와 같이 3가지 이다.


1.  192.168.0.0/16

2.  10.0.0.0/8

3.  172.16.0.0/12, 


슬래쉬(/) 뒷부분은 masking이므로


1. 192.168.0.0 의 경우 앞에서 부터 16비트 즉 2byte는 고정된다는 말이므로 192.168로 시작하는 모든 IP가 사설IP이다.

 

2. 10.0.0.0/8 의 경우는 8bite=1byte  즉 10만 고정되므로 10.x.x.x 모든 대역이 사설 IP이다.


3. 172.16.0.0/12의 경우는 좀 어려운데  172.16  에서 두번째 16의 앞부분 4bit만 고정되므로 16을 2진수로 표현해 보면 00010000 , 즉 앞 부분 0001을 고정시키면  뒷부분의 경우 0000~1111까지 변화가 가능하다.

즉 00010000~00011111까지가 가능하므로  172.16.x.x~172.31.x.x 까지가 사설 IP이다. 

Posted by yongary
,

OpenAPI, REST방식

IT 2008. 1. 16. 14:59

요즘 OpenAPI 에서는 REST방식이 대세이다.
simple해서 누구나 쉽게 만들 수 있고, RSS와도 유사한 면이 많기 때문에
그 이해와 구현의 접근성에서 기존의 다른 방식과는 비교를 불허한다고 할 수 있다.

REST(Representational State Transfer) 방식:
http 프로토콜의 GET, POST, PUT, DELETE의 4가지 방식을 이용해
각각 read, update, insert, delete의 형태로 데이타를 전달하는 방식이다.


기존 WEB Service 방식은  WSDL(웹 서비스 기술 언어) 를 이용해
언어를 정의하고, 데이타를 정의한 후 데이타를 주고 받아야 하므로
복잡한 측면이 존재한다.

SOAP 방식(Simple Object Access Protocol)도 WEB Service방식의 하나라고 볼 수 있는데
xml로 데이타를 전달하는 방식이다.
Posted by yongary
,

MCE 기능들

IT 2007. 11. 16. 13:28
(2006.05)

내가 느낀 MCE의 좋은 점을 나열하자면..
TV녹화와 리모컨이 매우 뛰어나다.

특히 나같이 소파에 누워서 모든 작업을 하려는 사람들에게는

이러한 MCE와 리모컨은 새로운 세상과도 같이 보인다..

1.  MCE가 있기 전에는 미국드라마(Lost,위기의 주부, 24 등등)을 노트북에 받아서
TV랑 연결해서 받는데.. 이 작업이 매번 너무너무 귀찮았다.
MCE를 거실에 두면, 리모컨으로 이런 미국드라마 보기를 모두 할 수 있다. 

단, 인터넷에 접속해서 다운로드 까지 하려면 MCE용 무선 키보드가 있는 게 좋다.


삼성PC의 경우는 리모컨으로 마우스나 키보드도 어느정도 되기 때문에..
MCE용 무선 키보드 없이도,  미국드라마 다운로드도 어느정도 리모컨으로 가능하다.

(다운로드를 하려면, MCE를 끄고, 인터넷 익스플로러를 뛰워서 해야 하므로

TV가 커야 소파에서 가능하다. )


2. TV녹화,예약녹화가 리모컨으로 간단히되니 아주 편리하다.

일단 MCE는 지역방송국 (강남케이블, 안양방송, 관악방송 등등) 과 연결되어 TV프로 목록을 다 받아온다. (EPG라는 회사에서 EPG솔루션을 MS와 계약하에 제공한다고 함)

사용자는  TV프로 목록을 브라우징 하다가 리모컨 버튼만 누르면 나중에  자동으로 녹화가 된다... 저는 새벽에 벌어질 독일 월드컵 축구를 이렇게 녹화해서 볼 수 있을 것 같다.

물론 PVR기능도 되지만.. 나는 일단 MCE를 녹화용도로만 사용할 계획이다.


3. CD 리핑기능도 편하고 좋다..

내가 가지고 있는 대부분의 CD들을 하드에 mp3로 만들어 놓고,

마우스로 원하는걸 언제든지 들을 수 있을 것 같다..


하드디스크가 160G인데,  이런걸 다하려니 벌써 압박이 들어오는 것 같긴 하다..^^


Posted by yongary
,