[IBM HTTPServer] SSL/TLS ์•”ํ˜ธํ™” ์ŠˆํŠธ(Cipher Suite) ํ™•์ธ ๋ฐ ์ ๊ฒ€ ๋ฐฉ๋ฒ• (DUMP_SSL_CIPHERS)

IBM HTTP Server(IHS)์—์„œ ํ˜„์žฌ ์ ์šฉ๋œ SSL/TLS ํ”„๋กœํ† ์ฝœ ๋ฒ„์ „๊ณผ ์ง€์›ํ•˜๋Š” ์•”ํ˜ธํ™” ์ŠˆํŠธ(Cipher Suite) ๋ชฉ๋ก์„ ํ™•์ธํ•˜๋Š” ๋ฐฉ๋ฒ•์„ ์ •๋ฆฌํ•ฉ๋‹ˆ๋‹ค. apachectl์˜ ์ง„๋‹จ ์˜ต์…˜์„ ํ†ตํ•ด ์„œ๋ฒ„์— ์„ค์ •๋œ ๋ณด์•ˆ ์ˆ˜์ค€์„ ์ ๊ฒ€ํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

0. ๋ฐฐ๊ฒฝ ์ง€์‹ (Context)

๋ณด์•ˆ ์ทจ์•ฝ์  ์ ๊ฒ€ ์‹œ "SSLv3๋‚˜ RC4 ๊ฐ™์€ ์•ฝํ•œ ์•”ํ˜ธํ™” ์•Œ๊ณ ๋ฆฌ์ฆ˜์„ ๋น„ํ™œ์„ฑํ™”ํ•˜๋ผ"๋Š” ๊ถŒ๊ณ ๋ฅผ ์ž์ฃผ ๋ฐ›์Šต๋‹ˆ๋‹ค. ์กฐ์น˜๋ฅผ ์ทจํ•˜๊ธฐ ์ „์—, ํ˜„์žฌ ์›น ์„œ๋ฒ„๊ฐ€ ์–ด๋–ค ์•Œ๊ณ ๋ฆฌ์ฆ˜์„ ํ—ˆ์šฉํ•˜๊ณ  ์žˆ๋Š”์ง€ ์ •ํ™•ํžˆ ํŒŒ์•…ํ•˜๋Š” ๊ฒƒ์ด ์šฐ์„ ์ž…๋‹ˆ๋‹ค.

Test Environment

  • OS: CentOS 7.2
  • Web Server: IBM HTTPServer v8.5.0.0

1. Cipher Suite ํ™•์ธ ๋ช…๋ น์–ด

IHS๋Š” apachectl ์‹คํ–‰ ์Šคํฌ๋ฆฝํŠธ์— -t(๋ฌธ๋ฒ• ๊ฒ€์‚ฌ) ์˜ต์…˜๊ณผ ํ•จ๊ป˜ -D DUMP_SSL_CIPHERS ์ •์˜๋ฅผ ์ถ”๊ฐ€ํ•˜์—ฌ, ํ˜„์žฌ ์„ค์ •๋œ SSL ๊ตฌ์„ฑ์„ ์ถœ๋ ฅํ•˜๋Š” ๊ธฐ๋Šฅ์„ ์ œ๊ณตํ•ฉ๋‹ˆ๋‹ค.

๋ช…๋ น์–ด ์‹คํ–‰

cd [IHS_HOME]/bin

# SSL Cipher ์„ค์ • ๋คํ”„
./apachectl -t -D DUMP_SSL_CIPHERS

๊ฒฐ๊ณผ ์ถœ๋ ฅ ์˜ˆ์‹œ (Default ์ƒํƒœ)

๋ณ„๋„์˜ ๋ณด์•ˆ ์„ค์ •(Hardening)์ด ๋˜์–ด ์žˆ์ง€ ์•Š๋‹ค๋ฉด, ์•„๋ž˜์™€ ๊ฐ™์ด IHS ๋ฒ„์ „์˜ ๊ธฐ๋ณธ๊ฐ’(Default)๋“ค์ด ์ถœ๋ ฅ๋ฉ๋‹ˆ๋‹ค.

SSL default cipher lists:
SSL protocol SSLV2, FIPS off, defaults = (None)
SSL protocol SSLV3, FIPS off, defaults = TLS_RSA_WITH_AES_128_CBC_SHA(2F), ...
SSL protocol TLSv10, FIPS off, defaults = TLS_RSA_WITH_AES_128_CBC_SHA(2F), ...
SSL protocol TLSv11, FIPS off, defaults = TLS_RSA_WITH_AES_128_CBC_SHA(2F), ...
SSL protocol TLSv12, FIPS off, defaults = TLS_RSA_WITH_AES_128_GCM_SHA256(9C), ...
Syntax OK
ํ•ด์„ ์ฃผ์˜ (Analysis):
์œ„ ์ถœ๋ ฅ ๊ฒฐ๊ณผ์— SSLV3 ํ•ญ๋ชฉ์ด ๋ณด์ธ๋‹ค๋ฉด, ํ˜„์žฌ ์„œ๋ฒ„๋Š” ๋ณด์•ˆ์— ์ทจ์•ฝํ•œ SSLv3 ํ”„๋กœํ† ์ฝœ ํ†ต์‹ ์„ ํ—ˆ์šฉํ•˜๊ณ  ์žˆ๋‹ค๋Š” ๋œป์ž…๋‹ˆ๋‹ค. ๋ณด์•ˆ ๊ฐ•ํ™”๋ฅผ ์œ„ํ•ด ๋น„ํ™œ์„ฑํ™”๊ฐ€ ํ•„์š”ํ•ฉ๋‹ˆ๋‹ค.

2. ์™ธ๋ถ€ ๋„๊ตฌ๋ฅผ ์ด์šฉํ•œ ๊ต์ฐจ ๊ฒ€์ฆ (Verification)

์„œ๋ฒ„ ๋‚ด๋ถ€ ์„ค์ •๋ฟ๋งŒ ์•„๋‹ˆ๋ผ, ์™ธ๋ถ€์—์„œ ์‹ค์ œ๋กœ ์ ‘์†์„ ์‹œ๋„ํ•˜์—ฌ ์–ด๋–ค Cipher๊ฐ€ ๋…ธ์ถœ๋˜๋Š”์ง€ ํ™•์ธํ•˜๋Š” ๊ฒƒ์ด ๊ฐ€์žฅ ์ •ํ™•ํ•ฉ๋‹ˆ๋‹ค.

1) nmap ์‚ฌ์šฉ (Linux)

nmap์˜ ์Šคํฌ๋ฆฝํŠธ ์—”์ง„์„ ์‚ฌ์šฉํ•˜์—ฌ ์ง€์›ํ•˜๋Š” Cipher ๋ชฉ๋ก์„ ์กฐํšŒํ•ฉ๋‹ˆ๋‹ค.

nmap --script ssl-enum-ciphers -p 443 [์„œ๋ฒ„IP]

2) OpenSSL ์‚ฌ์šฉ

ํŠน์ • ํ”„๋กœํ† ์ฝœ๋กœ ์ ‘์†์ด ๋˜๋Š”์ง€ ํ…Œ์ŠคํŠธํ•ฉ๋‹ˆ๋‹ค.

# SSLv3 ์ ‘์† ์‹œ๋„ (์ ‘์† ์‹คํŒจํ•ด์•ผ ์•ˆ์ „ํ•จ)
openssl s_client -connect [์„œ๋ฒ„IP]:443 -ssl3

3. ๋ณด์•ˆ ์„ค์ • ๊ฐ•ํ™” (Next Step)

์ทจ์•ฝํ•œ ํ”„๋กœํ† ์ฝœ๊ณผ Cipher๋ฅผ ํ™•์ธํ–ˆ๋‹ค๋ฉด, httpd.conf ํŒŒ์ผ์—์„œ ์ด๋ฅผ ์ฐจ๋‹จํ•ด์•ผ ํ•ฉ๋‹ˆ๋‹ค.

์„ค์ • ์˜ˆ์‹œ (httpd.conf)

IHS์—์„œ๋Š” SSLCipherSpec ์ง€์‹œ์–ด๋ฅผ ์‚ฌ์šฉํ•˜์—ฌ ํŠน์ • Cipher๋ฅผ ํ—ˆ์šฉํ•˜๊ฑฐ๋‚˜ ์ฐจ๋‹จํ•ฉ๋‹ˆ๋‹ค.

<VirtualHost *:443>
    SSLEnable
    
    # 1. ์ทจ์•ฝํ•œ ํ”„๋กœํ† ์ฝœ ๋น„ํ™œ์„ฑํ™” (TLS 1.2๋งŒ ํ—ˆ์šฉ ๊ถŒ์žฅ)
    SSLProtocolDisable SSLv2 SSLv3 TLSv10 TLSv11
    SSLProtocolEnable TLSv12

    # 2. ๊ฐ•๋ ฅํ•œ Cipher Suite๋งŒ ํ—ˆ์šฉ (์˜ˆ์‹œ)
    # 128๋น„ํŠธ ๋ฏธ๋งŒ ์ฐจ๋‹จ, RC4/MD5 ์ฐจ๋‹จ
    SSLCipherSpec TLS_RSA_WITH_AES_128_CBC_SHA
    SSLCipherSpec TLS_RSA_WITH_AES_256_CBC_SHA
    # ํ•„์š”์— ๋”ฐ๋ผ ์ถ”๊ฐ€...
</VirtualHost>

4. ์ฐธ๊ณ  ์ž๋ฃŒ (References)

[JBoss EAP 6] ์ปค์Šคํ…€ ๊ธฐ๋™/์ •์ง€ ์Šคํฌ๋ฆฝํŠธ ์ž‘์„ฑ ๊ฐ€์ด๋“œ (Config ๋ถ„๋ฆฌ ๋ฐ JVM ํŠœ๋‹)

JBoss EAP 6 Standalone ๋ชจ๋“œ์˜ ์šด์˜ ํšจ์œจ์„ฑ์„ ๋†’์ด๊ธฐ ์œ„ํ•ด, JVM ์˜ต์…˜๊ณผ ํ™˜๊ฒฝ ๋ณ€์ˆ˜๋ฅผ ๋ณ„๋„์˜ ์„ค์ • ํŒŒ์ผ(Config Shell)๋กœ ๋ถ„๋ฆฌํ•˜๊ณ  ์ด๋ฅผ ๋กœ๋“œํ•˜์—ฌ ์„œ๋ฒ„๋ฅผ ์ œ์–ด(Start/Stop/Status)ํ•˜๋Š” ์ปค์Šคํ…€ ์‰˜ ์Šคํฌ๋ฆฝํŠธ ์ž‘์„ฑ๋ฒ•์„ ๊ณต์œ ํ•ฉ๋‹ˆ๋‹ค.

Test Environment

  • OS: CentOS 7.2
  • Middleware: JBoss EAP 6.4

1. ์Šคํฌ๋ฆฝํŠธ ๊ตฌ์กฐ ๋ฐ ์ „๋žต

์œ ์ง€๋ณด์ˆ˜์„ฑ๊ณผ ํ™•์žฅ์„ฑ์„ ์œ„ํ•ด ์Šคํฌ๋ฆฝํŠธ๋ฅผ ๋‘ ๊ฐœ์˜ ํŒŒ์ผ๋กœ ๋ถ„๋ฆฌํ•ฉ๋‹ˆ๋‹ค.

  1. Config Script (config1.sh): JVM ์˜ต์…˜, ๊ฒฝ๋กœ, IP, ํฌํŠธ ๋“ฑ ๋ณ€์ˆ˜ ์ •์˜.
  2. Control Script (jboss_ctl.sh): Config๋ฅผ ๋กœ๋“œํ•˜์—ฌ ์‹ค์ œ ํ”„๋กœ์„ธ์Šค๋ฅผ ์ œ์–ดํ•˜๋Š” ๋กœ์ง.

2. ์„ค์ • ์Šคํฌ๋ฆฝํŠธ (config1.sh)

์„œ๋ฒ„ ์ธ์Šคํ„ด์Šค๋ณ„ ๊ณ ์œ ํ•œ ์„ค์ •์„ ์ด๊ณณ์— ์ •์˜ํ•ฉ๋‹ˆ๋‹ค. JAVA_OPTS๋ฅผ ํ†ตํ•ด ๋ฉ”๋ชจ๋ฆฌ ๋ฐ GC ๋กœ๊ทธ ์„ค์ •์„ ์ƒ์„ธํ•˜๊ฒŒ ํŠœ๋‹ํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

#!/bin/sh
DATE=`date +%Y%m%d%H%M%S`

##### 1. Basic Configuration #####
export JBOSS_HOME=/SW/was/JBoss
export SERVER_HOME=/SW/was/JBoss/TEST/TESTServer11
export LOG_PATH=/app/logs/was
export NODE_NAME=TESTServer11
export CONFIG_FILE=standalone-ha.xml

# Network & Port Offset
export SERVER_IP=10.252.16.25
export PORT_OFFSET=750
export MGMT_ADDR=$SERVER_IP

# Controller Port Calculation (Base 9999 + Offset)
let CONTROLLER_PORT=9999+$PORT_OFFSET
export CONTROLLER_PORT

# Admin User (Shutdown์šฉ)
export USER=admin

##### 2. JVM Options (Memory & GC) #####
# Heap Memory
export JAVA_OPTS="-server -Xms1024m -Xmx2048m -XX:MaxPermSize=256m"

# GC Logging
export JAVA_OPTS=" $JAVA_OPTS -verbose:gc -XX:+PrintGCTimeStamps -XX:+PrintGCDetails "
export JAVA_OPTS=" $JAVA_OPTS -Xloggc:$LOG_PATH/log/gclog/gc_$DATE.log "

# GC Algorithm (ParallelGC)
export JAVA_OPTS=" $JAVA_OPTS -XX:+UseParallelGC -XX:+ExplicitGCInvokesConcurrent"

# Heap Dump on OOM
export JAVA_OPTS=" $JAVA_OPTS -XX:-HeapDumpOnOutOfMemoryError "
export JAVA_OPTS=" $JAVA_OPTS -XX:HeapDumpPath=$LOG_PATH/heap/$NODE_NAME "

##### 3. System Properties (-D options) #####
export JAVA_OPTS=" $JAVA_OPTS -Djava.net.preferIPv4Stack=true"
export JAVA_OPTS=" $JAVA_OPTS -Dorg.jboss.resolver.warning=true"
export JAVA_OPTS=" $JAVA_OPTS -Djava.awt.headless=true"
export JAVA_OPTS=" $JAVA_OPTS -DjvmRoute=$NODE_NAME"

# JBoss Path & Binding
export JAVA_OPTS=" $JAVA_OPTS -Djboss.server.base.dir=$SERVER_HOME"
export JAVA_OPTS=" $JAVA_OPTS -Djboss.server.log.dir=$LOG_PATH/$NODE_NAME"
export JAVA_OPTS=" $JAVA_OPTS -Djboss.socket.binding.port-offset=$PORT_OFFSET"
export JAVA_OPTS=" $JAVA_OPTS -Djboss.node.name=$NODE_NAME"
export JAVA_OPTS=" $JAVA_OPTS -Djboss.bind.address.management=$MGMT_ADDR"
export JAVA_OPTS=" $JAVA_OPTS -Djboss.bind.address=$SERVER_IP"

# Clustering (Multicast)
export JAVA_OPTS=" $JAVA_OPTS -Djboss.default.jgroups.stack=tcp"
# export JAVA_OPTS=" $JAVA_OPTS -Djboss.default.multicast.address=230.1.0.1"

echo "Configuration Loaded: $NODE_NAME"

3. ์ œ์–ด ์Šคํฌ๋ฆฝํŠธ (jboss_ctl.sh)

์‹ค์ œ ๊ธฐ๋™ ๋ฐ ์ •์ง€๋ฅผ ๋‹ด๋‹นํ•˜๋Š” ๋ฉ”์ธ ์Šคํฌ๋ฆฝํŠธ์ž…๋‹ˆ๋‹ค. ./config/config1.sh๋ฅผ ๋กœ๋“œํ•˜์—ฌ ๋ณ€์ˆ˜๋“ค์„ ๊ฐ€์ ธ์˜ต๋‹ˆ๋‹ค.

#!/bin/sh

# Config ํŒŒ์ผ ๋กœ๋“œ (๊ฒฝ๋กœ ์ฃผ์˜)
. ./config/config1.sh

start(){
    # ํ”„๋กœ์„ธ์Šค ์ค‘๋ณต ์‹คํ–‰ ๋ฐฉ์ง€
    PID=`ps -ef | grep java | grep "jboss.node.name=$NODE_NAME " | awk '{print $2}'`
    
    if [ "x$PID" != "x" ]; then
        echo "###############################################"
        echo "ERROR: JBoss SERVER ($NODE_NAME) is already RUNNING (PID=$PID)"
        echo "###############################################"
        exit 1
    fi

    echo "#######################"
    echo "   Starting JBoss EAP  "
    echo "#######################"
    
    # nohup์œผ๋กœ ๋ฐฑ๊ทธ๋ผ์šด๋“œ ์‹คํ–‰, ๋กœ๊ทธ ๋ฆฌ๋‹ค์ด๋ ‰์…˜
    nohup $JBOSS_HOME/bin/standalone.sh --server-config=$CONFIG_FILE >> $LOG_PATH/console.log 2>&1 &

    echo "Starting... Wait for checking status..."
    sleep 5
    status
}

stop(){
    echo "#######################"
    echo "    Stopping JBoss     "
    echo "#######################"
    
    # ๋ณด์•ˆ์„ ์œ„ํ•ด ํŒจ์Šค์›Œ๋“œ๋Š” ์ž…๋ ฅ๋ฐ›๋„๋ก ์ฒ˜๋ฆฌ (์ž๋™ํ™” ์‹œ ๋ณ€์ˆ˜๋กœ ๋Œ€์ฒด ๊ฐ€๋Šฅ)
    echo -n "Enter Controller Password: "
    read -s PASSWORD
    echo ""

    # CLI๋ฅผ ์ด์šฉํ•œ ์•ˆ์ „ํ•œ ์ข…๋ฃŒ (Graceful Shutdown)
    $JBOSS_HOME/bin/jboss-cli.sh --connect --controller=$SERVER_IP:$CONTROLLER_PORT --command=:shutdown --user=$USER --password=$PASSWORD
}

status() {
    # ํฌํŠธ ๋ฆฌ์Šจ ์ƒํƒœ๋กœ ๊ตฌ๋™ ์—ฌ๋ถ€ ํ™•์ธ
    _up=`netstat -an | grep $CONTROLLER_PORT | grep LISTEN | wc -l`
    
    if [ "$_up" -ne 0 ]; then
        PID=`ps -ef | grep java | grep "jboss.node.name=$NODE_NAME " | awk '{print $2}'`
        echo "###############################################"
        echo " JBoss Server is RUNNING !! "
        echo " Node: $NODE_NAME (PID: $PID)"
        echo " Port: $CONTROLLER_PORT (Management)"
        echo "###############################################"
    else
        echo "##################################"
        echo " JBoss Server is STOPPED !! "
        echo " Node: $NODE_NAME "
        echo "##################################"
    fi
}

# ํŒŒ๋ผ๋ฏธํ„ฐ ์ฒ˜๋ฆฌ
case "$1" in
  start)
    start
    ;;
  stop)
    stop
    ;;
  status)
    status
    ;;
  restart)
    stop
    sleep 5
    start
    ;;
  *)
    echo "Usage: $0 {start|stop|status|restart}"
    exit 1
esac
exit 0

4. ์‚ฌ์šฉ ๋ฐฉ๋ฒ• ๋ฐ ์ฃผ์˜์‚ฌํ•ญ

์‚ฌ์šฉ๋ฒ•

# ์‹คํ–‰ ๊ถŒํ•œ ๋ถ€์—ฌ
chmod +x jboss_ctl.sh

# ๊ธฐ๋™
./jboss_ctl.sh start

# ์ƒํƒœ ํ™•์ธ
./jboss_ctl.sh status

# ์ •์ง€ (ํŒจ์Šค์›Œ๋“œ ์ž…๋ ฅ ํ•„์š”)
./jboss_ctl.sh stop
Tip: config1.sh ํŒŒ์ผ ๋‚ด์˜ PORT_OFFSET ๋ณ€์ˆ˜๋ฅผ ํ™œ์šฉํ•˜๋ฉด, ํ•˜๋‚˜์˜ ๋ฌผ๋ฆฌ ์„œ๋ฒ„์—์„œ ํฌํŠธ ์ถฉ๋Œ ์—†์ด ์—ฌ๋Ÿฌ ๊ฐœ์˜ ์ธ์Šคํ„ด์Šค๋ฅผ ๋„์šธ ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค. (์˜ˆ: 0, 100, 200...)

[Linux/Java] High CPU ํŠธ๋Ÿฌ๋ธ”์ŠˆํŒ…: OS ์Šค๋ ˆ๋“œ์™€ Java ์Šค๋ ˆ๋“œ ๋งคํ•‘ ๋ถ„์„ ๊ฐ€์ด๋“œ

Java ํ”„๋กœ์„ธ์Šค(JVM)๊ฐ€ ๊ณ ๋ถ€ํ•˜ ์ƒํƒœ์ผ ๋•Œ, CPU๋ฅผ ์ ์œ ํ•˜๊ณ  ์žˆ๋Š” ๋ฒ”์ธ(ํŠน์ • ์Šค๋ ˆ๋“œ)์„ ์ฐพ์•„๋‚ด๋Š” ๋ฐฉ๋ฒ•์„ ์ •๋ฆฌํ•ฉ๋‹ˆ๋‹ค. OS ๋ช…๋ น์–ด(ps, top)๋กœ ๋ฌธ์ œ์˜ ์Šค๋ ˆ๋“œ ID(TID)๋ฅผ ์‹๋ณ„ํ•˜๊ณ , ์ด๋ฅผ 16์ง„์ˆ˜๋กœ ๋ณ€ํ™˜ํ•˜์—ฌ Java Thread Dump์™€ ๋งคํ•‘ํ•˜๋Š” ๊ณผ์ •์„ ๋‹ค๋ฃน๋‹ˆ๋‹ค.

Test Environment

  • OS: RedHat Linux (CentOS ํ˜ธํ™˜)
  • Target: Java Process (WebSphere/Tomcat ๋“ฑ)

1. ํ”„๋กœ์„ธ์Šค ๋ฐ ์Šค๋ ˆ๋“œ ์‹๋ณ„ (Identify Usage)

๋จผ์ € CPU๋ฅผ ๋งŽ์ด ์‚ฌ์šฉํ•˜๋Š” Java ํ”„๋กœ์„ธ์Šค์˜ PID(Process ID)๋ฅผ ์ฐพ๊ณ , ๊ทธ ๋‚ด๋ถ€์—์„œ ์‹ค์ œ๋กœ ๋ฆฌ์†Œ์Šค๋ฅผ ์†Œ๋ชจํ•˜๋Š” ์Šค๋ ˆ๋“œ(LWP, Light Weight Process)๋ฅผ ์‹๋ณ„ํ•ด์•ผ ํ•ฉ๋‹ˆ๋‹ค.

์ „์ฒด ํ”„๋กœ์„ธ์Šค ํ™•์ธ

# Java ํ”„๋กœ์„ธ์Šค PID ํ™•์ธ
ps -ef | grep java

์Šค๋ ˆ๋“œ๋ณ„ CPU ์ ์œ ์œจ ํ™•์ธ (top)

-H ์˜ต์…˜์„ ์‚ฌ์šฉํ•˜์—ฌ ํ”„๋กœ์„ธ์Šค ๋‚ด๋ถ€์˜ ์Šค๋ ˆ๋“œ ๋‹จ์œ„๋กœ ๋ฆฌ์†Œ์Šค๋ฅผ ๋ชจ๋‹ˆํ„ฐ๋งํ•ฉ๋‹ˆ๋‹ค.

# PID๊ฐ€ 12345์ธ ๊ฒฝ์šฐ
top -H -p 12345

์ถœ๋ ฅ ํ™”๋ฉด์—์„œ PID(์‹ค์ œ๋กœ๋Š” TID/LWP) ์ปฌ๋Ÿผ๊ณผ %CPU ์ปฌ๋Ÿผ์„ ํ™•์ธํ•˜์—ฌ ๊ฐ€์žฅ ์ƒ๋‹จ์— ์žˆ๋Š” ๋ฒˆํ˜ธ๋ฅผ ๊ธฐ๋กํ•ฉ๋‹ˆ๋‹ค.

์Šค๋ ˆ๋“œ๋ณ„ CPU ์ ์œ ์œจ ํ™•์ธ (ps)

ps ๋ช…๋ น์–ด๋ฅผ ํ†ตํ•ด์„œ๋„ ์Šค๋ ˆ๋“œ ์ •๋ณด๋ฅผ ํ™•์ธํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค. -lmT ์˜ต์…˜์ด๋‚˜ -L ์˜ต์…˜์„ ์‚ฌ์šฉํ•ฉ๋‹ˆ๋‹ค.

# LWP(Light Weight Process) ํ™•์ธ
ps -lmT [PID]

# ๋˜๋Š” ์ปค์Šคํ…€ ํฌ๋งท ์‚ฌ์šฉ
ps -eLo pid,lwp,pcpu,comm | grep [PID]

2. ์Šค๋ ˆ๋“œ ID ๋ณ€ํ™˜ (Decimal to Hex)

OS์—์„œ ํ™•์ธํ•œ ์Šค๋ ˆ๋“œ ID๋Š” 10์ง„์ˆ˜(Decimal)์ด์ง€๋งŒ, Java Thread Dump ํŒŒ์ผ(Javacore ๋“ฑ)์—์„œ๋Š” ์Šค๋ ˆ๋“œ ID๊ฐ€ 16์ง„์ˆ˜(Hexadecimal)๋กœ ๊ธฐ๋ก๋ฉ๋‹ˆ๋‹ค. ๋”ฐ๋ผ์„œ ๋งคํ•‘์„ ์œ„ํ•ด ๋ณ€ํ™˜ ๊ณผ์ •์ด ํ•„์š”ํ•ฉ๋‹ˆ๋‹ค.

๋ณ€ํ™˜ ์˜ˆ์‹œ

  • OS TID: 9091 (10์ง„์ˆ˜)
  • Hex TID: 0x2383 (16์ง„์ˆ˜)

๋ณ€ํ™˜ ๋ช…๋ น์–ด

# ์‰˜์—์„œ ๋ฐ”๋กœ ๋ณ€ํ™˜ํ•˜๊ธฐ (์˜ˆ: 9091 -> 2383)
printf '%x\n' 9091

3. ์Šค๋ ˆ๋“œ ๋คํ”„ ์ƒ์„ฑ ๋ฐ ๋ถ„์„ (Thread Dump)

ํ˜„์žฌ JVM์˜ ์ƒํƒœ๋ฅผ ์Šค๋ƒ…์ƒท์œผ๋กœ ๋‚จ๊ธฐ๊ธฐ ์œ„ํ•ด ์Šค๋ ˆ๋“œ ๋คํ”„๋ฅผ ์ƒ์„ฑํ•ฉ๋‹ˆ๋‹ค.

๋คํ”„ ์ƒ์„ฑ (Kill -3)

kill -3 ์‹œ๊ทธ๋„์€ ํ”„๋กœ์„ธ์Šค๋ฅผ ์ข…๋ฃŒํ•˜์ง€ ์•Š๊ณ  ํ‘œ์ค€ ์ถœ๋ ฅ(stdout)์ด๋‚˜ ๋กœ๊ทธ ํŒŒ์ผ๋กœ ์Šค๋ ˆ๋“œ ์ •๋ณด๋ฅผ ์ถœ๋ ฅํ•ฉ๋‹ˆ๋‹ค.

kill -3 [PID]
  • IBM JDK (WebSphere): javacore.YYYYMMDD.HHMMSS.pid.txt ํŒŒ์ผ ์ƒ์„ฑ
  • Oracle/Open JDK: catalina.out ๋˜๋Š” ์ง€์ •๋œ ๋กœ๊ทธ ํŒŒ์ผ์— ์ถœ๋ ฅ

๋กœ๊ทธ ๋งคํ•‘ ๋ถ„์„

์ƒ์„ฑ๋œ ๋คํ”„ ํŒŒ์ผ์—์„œ ์•ž์„œ ๋ณ€ํ™˜ํ•œ 16์ง„์ˆ˜ ๊ฐ’(์˜ˆ: 0x2383)์„ ๊ฒ€์ƒ‰ํ•ฉ๋‹ˆ๋‹ค. IBM JDK์˜ ๊ฒฝ์šฐ nid(Native ID) ๋˜๋Š” native_thread_id ํ•ญ๋ชฉ๊ณผ ๋งค์นญ๋ฉ๋‹ˆ๋‹ค.

/* Javacore ์˜ˆ์‹œ */
"WebContainer : 5" (TID:0x12345600, sys_thread_t:0x789abc00, state:R, native ID:0x2383) prio=5
    at com.example.MyClass.infiniteLoop(MyClass.java:45)
    at ...

๋ถ„์„ ํฌ์ธํŠธ:

  1. 16์ง„์ˆ˜ ID๋กœ ๊ฒ€์ƒ‰ํ•˜์—ฌ ํ•ด๋‹น ์Šค๋ ˆ๋“œ๋ฅผ ์ฐพ์Šต๋‹ˆ๋‹ค.
  2. ํ•ด๋‹น ์Šค๋ ˆ๋“œ์˜ ์ƒํƒœ(Runnable, Waiting ๋“ฑ)๋ฅผ ํ™•์ธํ•ฉ๋‹ˆ๋‹ค.
  3. Stack Trace๋ฅผ ํ†ตํ•ด ํ˜„์žฌ ์–ด๋–ค ์ฝ”๋“œ(๋ฉ”์†Œ๋“œ)๊ฐ€ ์‹คํ–‰ ์ค‘์ธ์ง€ ํŒŒ์•…ํ•˜์—ฌ ๋ณ‘๋ชฉ ์ง€์ ์„ ์ˆ˜์ •ํ•ฉ๋‹ˆ๋‹ค.

Next Step:
์ฃผ๊ธฐ์ ์ธ ๋ชจ๋‹ˆํ„ฐ๋ง์ด ํ•„์š”ํ•˜๋‹ค๋ฉด top -H์™€ jstack์„ ๊ฒฐํ•ฉํ•œ ์‰˜ ์Šคํฌ๋ฆฝํŠธ๋ฅผ ์ž‘์„ฑํ•˜์—ฌ, CPU ์ž„๊ณ„์น˜ ์ดˆ๊ณผ ์‹œ ์ž๋™์œผ๋กœ ๋คํ”„๋ฅผ ๋‚จ๊ธฐ๋„๋ก ์ž๋™ํ™”ํ•ด ๋ณด์‹ญ์‹œ์˜ค.

[JBoss EAP 6] CLI ๊ธฐ๋ฐ˜ ํŒจ์น˜ ์ ์šฉ(Apply) ๋ฐ ๋กค๋ฐฑ(Rollback) ์™„๋ฒฝ ๊ฐ€์ด๋“œ

JBoss EAP 6 ํ™˜๊ฒฝ์—์„œ Management CLI(jboss-cli)๋ฅผ ์‚ฌ์šฉํ•˜์—ฌ ๋ณด์•ˆ ํŒจ์น˜๋‚˜ ๋ฒ„๊ทธ ํ”ฝ์Šค๋ฅผ ์ ์šฉ(Apply)ํ•˜๊ณ , ๋ฌธ์ œ ๋ฐœ์ƒ ์‹œ ์ด์ „ ์ƒํƒœ๋กœ ๋˜๋Œ๋ฆฌ๋Š” ๋กค๋ฐฑ(Rollback) ์ ˆ์ฐจ๋ฅผ ์ •๋ฆฌํ•ฉ๋‹ˆ๋‹ค. ํŒจ์น˜ ์ด๋ ฅ ๊ด€๋ฆฌ์™€ ์„ค์ • ์ดˆ๊ธฐํ™” ์˜ต์…˜์— ๋Œ€ํ•œ ์ดํ•ด๊ฐ€ ํ•„์ˆ˜์ ์ž…๋‹ˆ๋‹ค.

0. ๋ฐฐ๊ฒฝ ์ง€์‹ (Context)

JBoss EAP 6์˜ ํŒจ์น˜ ์‹œ์Šคํ…œ์€ ๋ˆ„์ (Cumulative) ๋ฐฉ์‹๊ณผ ๋‹จ์ผ(One-off) ๋ฐฉ์‹์œผ๋กœ ๋‚˜๋‰ฉ๋‹ˆ๋‹ค. ํŒจ์น˜๋ฅผ ์ ์šฉํ•˜๋ฉด ๋‚ด๋ถ€์ ์œผ๋กœ .installation ๋””๋ ‰ํ† ๋ฆฌ์— ๋ณ€๊ฒฝ ๋‚ด์—ญ์ด ์ €์žฅ๋˜๋ฉฐ, ์ด๋ฅผ ํ†ตํ•ด ์–ธ์ œ๋“  ์ด์ „ ์‹œ์ ์œผ๋กœ ๋ณต์›ํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

Test Environment

  • OS: Windows 10 (Linux ๋ช…๋ น์–ด ํฌํ•จ)
  • Middleware: JBoss EAP 6.4
  • Patch File: jboss-eap-6.4.19-patch.zip

1. ํŒจ์น˜ ์ ์šฉ (Patch Apply)

ํŒจ์น˜ ํŒŒ์ผ์„ ๋‹ค์šด๋กœ๋“œํ•œ ํ›„, JBoss๊ฐ€ ๊ฐ€๋™๋œ ์ƒํƒœ(๋˜๋Š” Embed ๋ชจ๋“œ)์—์„œ CLI๋ฅผ ํ†ตํ•ด ์ ์šฉํ•ฉ๋‹ˆ๋‹ค.

๋ช…๋ น์–ด ๊ตฌ๋ฌธ

# ๊ธฐ๋ณธ ๊ตฌ๋ฌธ
patch apply [ํŒจ์น˜ํŒŒ์ผ_๊ฒฝ๋กœ]

OS๋ณ„ ์‹คํ–‰ ์˜ˆ์‹œ

Linux

$JBOSS_HOME/bin/jboss-cli.sh --connect
[standalone@localhost:9999 /] patch apply /was/img/fix/jboss-eap-6.4.19-patch.zip

Windows

%JBOSS_HOME%\bin\jboss-cli.bat --connect
[standalone@localhost:9999 /] patch apply F:\app\was\jboss-eap-6.4.19-patch.zip
Note: ํŒจ์น˜ ์ ์šฉ ํ›„์—๋Š” ๋ณ€๊ฒฝ๋œ ๋ชจ๋“ˆ์„ ๋กœ๋“œํ•˜๊ธฐ ์œ„ํ•ด ๋ฐ˜๋“œ์‹œ ์„œ๋ฒ„๋ฅผ ์žฌ๊ธฐ๋™(Restart)ํ•ด์•ผ ํ•ฉ๋‹ˆ๋‹ค.

2. ํŒจ์น˜ ์ด๋ ฅ ํ™•์ธ (Verification)

ํŒจ์น˜๊ฐ€ ์ •์ƒ์ ์œผ๋กœ ์ ์šฉ๋˜์—ˆ๋Š”์ง€, ํ˜น์€ ๋กค๋ฐฑ์„ ์œ„ํ•ด ๋Œ์•„๊ฐˆ ์‹œ์ (ID)์„ ํ™•์ธํ•ด์•ผ ํ•ฉ๋‹ˆ๋‹ค.

CLI์—์„œ ํ™•์ธ

# ํŒจ์น˜ ์ •๋ณด ์กฐํšŒ
[standalone@localhost:9999 /] patch history

# ์ƒ์„ธ ์ •๋ณด ์กฐํšŒ
[standalone@localhost:9999 /] patch info

ํŒŒ์ผ ์‹œ์Šคํ…œ์—์„œ ํ™•์ธ

JBoss ์„ค์น˜ ๊ฒฝ๋กœ ๋‚ด์˜ ์ˆจ๊น€ ํด๋”๋ฅผ ํ†ตํ•ด์„œ๋„ ํ™•์ธ ๊ฐ€๋Šฅํ•ฉ๋‹ˆ๋‹ค.

  • ๊ฒฝ๋กœ: {JBoss_HOME}/.installation/patches

3. ํŒจ์น˜ ๋กค๋ฐฑ (Patch Rollback)

ํŒจ์น˜ ์ ์šฉ ํ›„ ์• ํ”Œ๋ฆฌ์ผ€์ด์…˜์— ๋ฌธ์ œ๊ฐ€ ์ƒ๊ฒผ๋‹ค๋ฉด ์ฆ‰์‹œ ์ด์ „ ์ƒํƒœ๋กœ ๋˜๋Œ๋ ค์•ผ ํ•ฉ๋‹ˆ๋‹ค.

์‚ฌ์ „ ์ค€๋น„: Patch ID ํ™•์ธ

๋กค๋ฐฑํ•  ๋Œ€์ƒ ID๋ฅผ ์•Œ์•„์•ผ ํ•ฉ๋‹ˆ๋‹ค. patch history ๋ช…๋ น์–ด๋กœ ๊ฐ€์žฅ ์ตœ๊ทผ์— ์ ์šฉ๋œ ํŒจ์น˜ ID๋ฅผ ํ™•์ธํ•˜์‹ญ์‹œ์˜ค.

๋กค๋ฐฑ ๋ช…๋ น์–ด

# ๊ตฌ๋ฌธ
patch rollback --patch-id=[PATCH_ID] --reset-configuration=[TRUE|FALSE]

ํ•ต์‹ฌ ์˜ต์…˜ ์„ค๋ช… (--reset-configuration)

  • TRUE (๊ถŒ์žฅ): ํŒจ์น˜ ์ ์šฉ ์‹œ ๋ณ€๊ฒฝ๋˜์—ˆ๋˜ ์„ค์ • ํŒŒ์ผ(standalone.xml ๋“ฑ)๋„ ํŒจ์น˜ ์ด์ „ ์ƒํƒœ๋กœ ๋˜๋Œ๋ฆฝ๋‹ˆ๋‹ค.
  • FALSE: ์„ค์ • ํŒŒ์ผ์€ ํ˜„ ์ƒํƒœ๋ฅผ ์œ ์ง€ํ•˜๊ณ  ๋ชจ๋“ˆ(Jar)๋งŒ ๋กค๋ฐฑํ•ฉ๋‹ˆ๋‹ค. ์„ค์ • ์ถฉ๋Œ๋กœ ์ธํ•ด ์„œ๋ฒ„ ๊ธฐ๋™์ด ์‹คํŒจํ•  ์ˆ˜ ์žˆ์œผ๋ฏ€๋กœ ์ฃผ์˜ํ•ด์•ผ ํ•ฉ๋‹ˆ๋‹ค.

์‹คํ–‰ ์˜ˆ์‹œ

# ์„ค์ •๊นŒ์ง€ ์™„๋ฒฝํ•˜๊ฒŒ ์ด์ „์œผ๋กœ ๋ณต๊ตฌ
[standalone@localhost:9999 /] patch rollback --patch-id=CP19 --reset-configuration=true

4. ๊ด€๋ฆฌ ์ฝ˜์†”(GUI)์„ ์ด์šฉํ•œ ๋ฐฉ๋ฒ•

CLI ์‚ฌ์šฉ์ด ์–ด๋ ต๋‹ค๋ฉด ์›น ๊ด€๋ฆฌ ์ฝ˜์†”์—์„œ๋„ ๋™์ผํ•œ ์ž‘์—…์„ ์ˆ˜ํ–‰ํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

  1. ์ ‘์†: http://localhost:9990/console
  2. ๋ฉ”๋‰ด: ์ƒ๋‹จ Patching ํƒญ ์„ ํƒ
  3. ์ž‘์—…: ํŒจ์น˜ ๋งˆ๋ฒ•์‚ฌ๋ฅผ ํ†ตํ•ด ํŒŒ์ผ ์—…๋กœ๋“œ ๋ฐ ์ ์šฉ (๋กค๋ฐฑ ๊ธฐ๋Šฅ ํฌํ•จ)
JBoss Management Console Patching Screen

[๊ทธ๋ฆผ] JBoss ๊ด€๋ฆฌ ์ฝ˜์†”์˜ ํŒจ์น˜ ๊ด€๋ฆฌ ํ™”๋ฉด


Next Step:
ํŒจ์น˜ ์ž‘์—… ์ „์—๋Š” ๋งŒ์•ฝ์„ ๋Œ€๋น„ํ•ด standalone ๋˜๋Š” domain ๋””๋ ‰ํ† ๋ฆฌ ์ „์ฒด๋ฅผ ์••์ถ•ํ•˜์—ฌ ๋ณ„๋„๋กœ ๋ฐฑ์—…ํ•ด๋‘๋Š” ๊ฒƒ์„ ๊ฐ•๋ ฅํžˆ ๊ถŒ์žฅํ•ฉ๋‹ˆ๋‹ค.

[WebSphere] ๋””๋ ‰ํ† ๋ฆฌ ๋ฆฌ์ŠคํŒ…(Directory Listing) ์ œ๊ฑฐ ๋ฐ ๋ณด์•ˆ ์„ค์ • (directoryBrowsingEnabled)

์›น ์„œ๋ฒ„๊ฐ€ ํŠน์ • ๋””๋ ‰ํ† ๋ฆฌ ๋‚ด์˜ ํŒŒ์ผ ๋ชฉ๋ก์„ ๋ธŒ๋ผ์šฐ์ €์— ๋…ธ์ถœํ•˜๋Š” '๋””๋ ‰ํ† ๋ฆฌ ๋ฆฌ์ŠคํŒ…' ์ทจ์•ฝ์ ์„ ํ•ด๊ฒฐํ•˜๊ธฐ ์œ„ํ•œ WebSphere ์„ค์ • ๊ฐ€์ด๋“œ์ž…๋‹ˆ๋‹ค. ์• ํ”Œ๋ฆฌ์ผ€์ด์…˜ ๋ ˆ๋ฒจ(xml) ์ˆ˜์ • ๋ฐฉ์‹๊ณผ ๊ด€๋ฆฌ ์ฝ˜์†”(Admin Console)์„ ํ†ตํ•œ ์ „์—ญ ์„ค์ • ๋ฐฉ์‹์„ ๋‹ค๋ฃน๋‹ˆ๋‹ค.

0. ๋ฐฐ๊ฒฝ ๋ฐ ์›์ธ (Context)

๋””๋ ‰ํ† ๋ฆฌ ๋ฆฌ์ŠคํŒ…์ด ํ™œ์„ฑํ™”๋˜์–ด ์žˆ์œผ๋ฉด ๊ณต๊ฒฉ์ž๊ฐ€ ์„œ๋ฒ„์˜ ๋””๋ ‰ํ† ๋ฆฌ ๊ตฌ์กฐ์™€ ํŒŒ์ผ ๋ชฉ๋ก(๋ฐฑ์—… ํŒŒ์ผ, ์†Œ์Šค ์ฝ”๋“œ ๋“ฑ)์„ ํŒŒ์•…ํ•  ์ˆ˜ ์žˆ์–ด 2์ฐจ ๊ณต๊ฒฉ์˜ ๋นŒ๋ฏธ๊ฐ€ ๋ฉ๋‹ˆ๋‹ค.

WebSphere๋Š” ์ •์  ํŒŒ์ผ ์ฒ˜๋ฆฌ๋ฅผ ์œ„ํ•œ fileServingEnabled ์†์„ฑ๊ณผ ๋ชฉ๋ก ๋…ธ์ถœ์„ ์œ„ํ•œ directoryBrowsingEnabled ์†์„ฑ์„ ๊ฐ€์ง€๊ณ  ์žˆ์œผ๋ฉฐ, ์ด๋ฅผ ์ ์ ˆํžˆ ์ œ์–ดํ•ด์•ผ ํ•ฉ๋‹ˆ๋‹ค.

Test Environment

  • OS: CentOS 7.2
  • Web Server: IBM HTTPServer v8.5.0.0
  • WAS: WebSphere Application Server v8.5

1. Method A: ์• ํ”Œ๋ฆฌ์ผ€์ด์…˜ ์„ค์ • ํŒŒ์ผ ์ˆ˜์ •

๊ฐœ๋ณ„ ์• ํ”Œ๋ฆฌ์ผ€์ด์…˜ ๋‹จ์œ„๋กœ ์„ค์ •์„ ์ ์šฉํ•  ๋•Œ ์‚ฌ์šฉํ•ฉ๋‹ˆ๋‹ค. WAR/EAR ํŒŒ์ผ ๋‚ด๋ถ€์˜ IBM ํ™•์žฅ ์„ค์ • ํŒŒ์ผ์„ ์ง์ ‘ ์ˆ˜์ •ํ•ฉ๋‹ˆ๋‹ค.

์„ค์ • ํŒŒ์ผ ๋Œ€์ƒ

  • WAS v7.0 ์ด์ƒ: ibm-web-ext.xml
  • WAS v6.1 ์ดํ•˜: ibm-web-ext.xmi (Legacy)

์„ค์ • ๋‚ด์šฉ (ibm-web-ext.xml)

enable-directory-browsing ์†์„ฑ์„ false๋กœ ๋ช…์‹œํ•ฉ๋‹ˆ๋‹ค.

<?xml version="1.0" encoding="UTF-8"?>
<web-ext
    xmlns="http://websphere.ibm.com/xml/ns/javaee/web-ext/1.0"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://websphere.ibm.com/xml/ns/javaee/web-ext/1.0 http://websphere.ibm.com/xml/ns/javaee/web-ext/1.0/web-ext.xsd">

    <!-- ์ •์  ํŒŒ์ผ ์„œ๋น™ ํ™œ์„ฑํ™” (์ด๋ฏธ์ง€, HTML ๋“ฑ) -->
    <enable-file-serving value="true"/>
    
    <!-- ํ•ต์‹ฌ: ๋””๋ ‰ํ† ๋ฆฌ ๋ฆฌ์ŠคํŒ… ๋น„ํ™œ์„ฑํ™” -->
    <enable-directory-browsing value="false"/>

</web-ext>

2. Method B: ์›น ์ปจํ…Œ์ด๋„ˆ(Web Container) ์ „์—ญ ์„ค์ •

WAS ๊ด€๋ฆฌ ์ฝ˜์†”์—์„œ ์„œ๋ฒ„ ๋‹จ์œ„๋กœ ์†์„ฑ์„ ์ถ”๊ฐ€ํ•˜์—ฌ ์ œ์–ดํ•˜๋Š” ๋ฐฉ์‹์ž…๋‹ˆ๋‹ค. ์• ํ”Œ๋ฆฌ์ผ€์ด์…˜์„ ์žฌ๋ฐฐํฌํ•˜์ง€ ์•Š๊ณ  ์„ค์ •์„ ๋ณ€๊ฒฝํ•  ์ˆ˜ ์žˆ์–ด ์šด์˜ ํ™˜๊ฒฝ์—์„œ ์„ ํ˜ธ๋ฉ๋‹ˆ๋‹ค.

์„ค์ • ๊ฒฝ๋กœ

์„œ๋ฒ„(Servers) > ์„œ๋ฒ„ ์œ ํ˜•(Server Types) > WebSphere application servers > [์„œ๋ฒ„๋ช…] > ์›น ์ปจํ…Œ์ด๋„ˆ ์„ค์ •(Web Container Settings) > ์›น ์ปจํ…Œ์ด๋„ˆ(Web container) > ์‚ฌ์šฉ์ž ์ •์˜ ํŠน์„ฑ(Custom properties)

์ฃผ์š” ์†์„ฑ ๊ฐ’

์•„๋ž˜ ์†์„ฑ์„ ์ƒˆ๋กœ ์ž‘์„ฑ(New)ํ•˜์—ฌ ์ถ”๊ฐ€ํ•ฉ๋‹ˆ๋‹ค.

์ด๋ฆ„ (Name) ๊ฐ’ (Value) ์„ค๋ช…
directoryBrowsingEnabled false ๋””๋ ‰ํ† ๋ฆฌ ๋ชฉ๋ก ์กฐํšŒ ๊ธฐ๋Šฅ์„ ๋น„ํ™œ์„ฑํ™”ํ•ฉ๋‹ˆ๋‹ค. (๋ณด์•ˆ ํ•„์ˆ˜)
fileServingEnabled true WAS๊ฐ€ ์ •์  ํŒŒ์ผ(html, img ๋“ฑ)์„ ์ฒ˜๋ฆฌํ• ์ง€ ์—ฌ๋ถ€์ž…๋‹ˆ๋‹ค. (false ์„ค์ • ์‹œ ์ •์  ํŒŒ์ผ ์ฒ˜๋ฆฌ๊ฐ€ ๋ถˆ๊ฐ€ํ•  ์ˆ˜ ์žˆ์Œ)
์ฐธ๊ณ : fileServingEnabled๋ฅผ false๋กœ ์„ค์ •ํ•˜๋ฉด ๋””๋ ‰ํ† ๋ฆฌ ๋ฆฌ์ŠคํŒ…๋„ ์ฐจ๋‹จ๋˜์ง€๋งŒ, WAS๊ฐ€ ์ด๋ฏธ์ง€๋‚˜ CSS ๊ฐ™์€ ์ •์  ๋ฆฌ์†Œ์Šค๋ฅผ ์ „ํ˜€ ์ œ๊ณตํ•˜์ง€ ์•Š๊ฒŒ ๋˜๋ฏ€๋กœ ์ฃผ์˜๊ฐ€ ํ•„์š”ํ•ฉ๋‹ˆ๋‹ค. ์ผ๋ฐ˜์ ์œผ๋กœ๋Š” directoryBrowsingEnabled๋งŒ false๋กœ ์„ค์ •ํ•ฉ๋‹ˆ๋‹ค.

3. ๊ฒ€์ฆ (Verification)

  1. ์„ค์ • ์ ์šฉ ํ›„ WAS ์ธ์Šคํ„ด์Šค๋ฅผ ์žฌ๊ธฐ๋™ํ•ฉ๋‹ˆ๋‹ค.
  2. ๋ธŒ๋ผ์šฐ์ €์—์„œ index.html์ด ์—†๋Š” ๋””๋ ‰ํ† ๋ฆฌ ๊ฒฝ๋กœ(์˜ˆ: http://domain/images/)๋กœ ์ ‘์†ํ•ฉ๋‹ˆ๋‹ค.
  3. 403 Forbidden ์—๋Ÿฌ๊ฐ€ ๋ฐœ์ƒํ•˜๋ฉด ๋ณด์•ˆ ์„ค์ •์ด ์ •์ƒ์ ์œผ๋กœ ์ ์šฉ๋œ ๊ฒƒ์ž…๋‹ˆ๋‹ค.

[OpenSSL/Apache] ์‚ฌ์„ค ์ธ์ฆ์„œ(Self-Signed Certificate) ์ƒ์„ฑ ๋ฐ ์ ์šฉ ์™„๋ฒฝ ๊ฐ€์ด๋“œ

๊ฐœ๋ฐœ ๋ฐ ํ…Œ์ŠคํŠธ ํ™˜๊ฒฝ์˜ HTTPS ๊ตฌํ˜„์„ ์œ„ํ•ด OpenSSL๋กœ ์‚ฌ์„ค ์ธ์ฆ์„œ๋ฅผ ์ƒ์„ฑํ•˜๋Š” ๋ฐฉ๋ฒ•์„ ์ •๋ฆฌํ•ฉ๋‹ˆ๋‹ค. ์‹ค๋ฌด์—์„œ ํ˜ผ๋™ํ•˜๊ธฐ ์‰ฌ์šด Key, CSR, CRT ํŒŒ์ผ์˜ ์ •ํ™•ํ•œ ์—ญํ•  ์ •์˜๋ถ€ํ„ฐ, ๊ฐœ์ธํ‚ค ํŒจ์Šค์›Œ๋“œ ์ œ๊ฑฐ ๋ฐ Apache ์ ์šฉ๊นŒ์ง€์˜ ์ „์ฒด ํ”„๋กœ์„ธ์Šค๋ฅผ ๋‹ค๋ฃน๋‹ˆ๋‹ค.

0. ๋ฐฐ๊ฒฝ ์ง€์‹: ์ธ์ฆ์„œ ํŒŒ์ผ์˜ ์ข…๋ฅ˜์™€ ์—ญํ• 

SSL ์ธ์ฆ์„œ ๋ฐœ๊ธ‰ ๊ณผ์ •์€ ๊ฐœ์ธํ‚ค ์ƒ์„ฑ → ์ธ์ฆ ์š”์ฒญ(CSR) → ์ธ์ฆ์„œ ๋ฐœ๊ธ‰(CRT)์˜ ์ˆœ์„œ๋กœ ์ง„ํ–‰๋ฉ๋‹ˆ๋‹ค. ๊ฐ ๋‹จ๊ณ„์—์„œ ์ƒ์„ฑ๋˜๋Š” ํŒŒ์ผ์˜ ์—ญํ• ์„ ๋ช…ํ™•ํžˆ ์ดํ•ดํ•ด์•ผ ํ•ฉ๋‹ˆ๋‹ค.

  • 1. Private Key (.key):
    • ์„œ๋ฒ„๊ฐ€ ๊ฐ–๋Š” ๋น„๋ฐ€ ์—ด์‡ ์ž…๋‹ˆ๋‹ค. ๋ฐ์ดํ„ฐ๋ฅผ ์•”ํ˜ธํ™”/๋ณตํ˜ธํ™”ํ•˜๋Š” ํ•ต์‹ฌ ํŒŒ์ผ๋กœ, ์ ˆ๋Œ€ ์™ธ๋ถ€๋กœ ์œ ์ถœ๋˜์–ด์„œ๋Š” ์•ˆ ๋ฉ๋‹ˆ๋‹ค.
    • ์ด ํ‚ค๋ฅผ ๋ถ„์‹คํ•˜๋ฉด ์ธ์ฆ์„œ๋ฅผ ์žฌ๋ฐœ๊ธ‰๋ฐ›์•„์•ผ ํ•ฉ๋‹ˆ๋‹ค.
  • 2. CSR (.csr - Certificate Signing Request):
    • ์ธ์ฆ ๊ธฐ๊ด€(CA)์— "๋‚ด ์ธ์ฆ์„œ๋ฅผ ๋งŒ๋“ค์–ด ๋‹ฌ๋ผ"๊ณ  ๋ณด๋‚ด๋Š” ์‹ ์ฒญ์„œ์ž…๋‹ˆ๋‹ค.
    • ๊ณต๊ฐœํ‚ค(Public Key) ์ •๋ณด์™€ ๋„๋ฉ”์ธ, ํšŒ์‚ฌ ์ •๋ณด(DN)๊ฐ€ ํฌํ•จ๋˜์–ด ์žˆ์Šต๋‹ˆ๋‹ค.
  • 3. Certificate (.crt):
    • ์ตœ์ข…์ ์œผ๋กœ ๋ฐœ๊ธ‰๋œ ์ธ์ฆ์„œ(์‹ ๋ถ„์ฆ)์ž…๋‹ˆ๋‹ค.
    • CSR ๋‚ด์šฉ์„ ๋ฐ”ํƒ•์œผ๋กœ CA(ํ˜น์€ ๋ณธ์ธ)๊ฐ€ ์ „์ž ์„œ๋ช…์„ ํ•œ ํŒŒ์ผ์ด๋ฉฐ, ํด๋ผ์ด์–ธํŠธ(๋ธŒ๋ผ์šฐ์ €)์—๊ฒŒ ์ „์†ก๋ฉ๋‹ˆ๋‹ค.

Test Environment

  • OS: CentOS 7.2
  • Web Server: Apache HTTP Server
  • Tool: OpenSSL

1. ๊ฐœ์ธํ‚ค(Private Key) ์ƒ์„ฑ

๊ฐ€์žฅ ๋จผ์ € ๋ชจ๋“  ์•”ํ˜ธํ™” ํ†ต์‹ ์˜ ๊ธฐ๋ฐ˜์ด ๋˜๋Š” ๊ฐœ์ธํ‚ค๋ฅผ ์ƒ์„ฑํ•ฉ๋‹ˆ๋‹ค.

1) ์•”ํ˜ธํ™”๋œ ๊ฐœ์ธํ‚ค ์ƒ์„ฑ

des3 ์•Œ๊ณ ๋ฆฌ์ฆ˜์„ ์‚ฌ์šฉํ•˜์—ฌ 2048๋น„ํŠธ ๊ธธ์ด์˜ RSA ํ‚ค๋ฅผ ์ƒ์„ฑํ•ฉ๋‹ˆ๋‹ค. ์ด๋•Œ ์„ค์ •ํ•˜๋Š” ํŒจ์Šค์›Œ๋“œ(Pass Phrase)๋Š” ํ‚ค๋ฅผ ๋ณดํ˜ธํ•˜๊ธฐ ์œ„ํ•œ ์žฅ์น˜์ž…๋‹ˆ๋‹ค.

[root@web01 test]# openssl genrsa -des3 -out test.vn.key 2048

Generating RSA private key, 2048 bit long modulus
..........................+++
e is 65537 (0x10001)
Enter pass phrase for test.vn.key: [ํŒจ์Šค์›Œ๋“œ ์ž…๋ ฅ]
Verifying - Enter pass phrase for test.vn.key: [ํŒจ์Šค์›Œ๋“œ ํ™•์ธ]

2) ๊ฐœ์ธํ‚ค ํŒจ์Šค์›Œ๋“œ ์ œ๊ฑฐ (ํ•„์ˆ˜ ๊ถŒ์žฅ)

ํŒจ์Šค์›Œ๋“œ๊ฐ€ ๊ฑธ๋ฆฐ ํ‚ค๋ฅผ ์›น ์„œ๋ฒ„์— ๊ทธ๋Œ€๋กœ ์ ์šฉํ•˜๋ฉด, ์„œ๋ฒ„๊ฐ€ ์žฌ๊ธฐ๋™๋  ๋•Œ๋งˆ๋‹ค ๊ด€๋ฆฌ์ž๊ฐ€ ๋งค๋ฒˆ ํŒจ์Šค์›Œ๋“œ๋ฅผ ์ž…๋ ฅํ•ด์•ผ ํ•ฉ๋‹ˆ๋‹ค. ์ž๋™ ์šด์˜์„ ์œ„ํ•ด ํŒจ์Šค์›Œ๋“œ๋ฅผ ์ œ๊ฑฐํ•œ ํ‚ค๋ฅผ ๋‹ค์‹œ ์ƒ์„ฑํ•ฉ๋‹ˆ๋‹ค.

# 1. ์›๋ณธ ํ‚ค ๋ฐฑ์—…
cp test.vn.key test.vn.key.orig

# 2. ํŒจ์Šค์›Œ๋“œ๊ฐ€ ์ œ๊ฑฐ๋œ ํ‚ค ์ƒ์„ฑ (๋ฎ์–ด์“ฐ๊ธฐ)
openssl rsa -in test.vn.key.orig -out test.vn.key

# ๊ฒฐ๊ณผ ๋ฉ”์‹œ์ง€
Enter pass phrase for test.vn.key.orig: [๊ธฐ์กด ํŒจ์Šค์›Œ๋“œ ์ž…๋ ฅ]
writing RSA key

2. ์ธ์ฆ ์š”์ฒญ์„œ(CSR) ์ƒ์„ฑ

์ƒ์„ฑ๋œ ๊ฐœ์ธํ‚ค(.key)๋ฅผ ๋ฐ”ํƒ•์œผ๋กœ ์ธ์ฆ์„œ ๋ฐœ๊ธ‰ ์‹ ์ฒญ์„œ(.csr)๋ฅผ ์ž‘์„ฑํ•ฉ๋‹ˆ๋‹ค.

CSR ์ƒ์„ฑ ๋ช…๋ น์–ด

openssl req -new -key test.vn.key -out test.vn.csr

์ฃผ์š” ์ž…๋ ฅ ์ •๋ณด (DN: Distinguished Name)

๋ช…๋ น ์‹คํ–‰ ํ›„ ์ž…๋ ฅํ•ด์•ผ ํ•  ์ •๋ณด์ž…๋‹ˆ๋‹ค. ๋‹ค๋ฅธ ์ •๋ณด๋Š” ์ž„์˜๋กœ ์ž…๋ ฅํ•ด๋„ ๋˜์ง€๋งŒ, Common Name์€ ๋ฐ˜๋“œ์‹œ ์ •ํ™•ํ•ด์•ผ ํ•ฉ๋‹ˆ๋‹ค.

  • Country Name: ๊ตญ๊ฐ€ ์ฝ”๋“œ (์˜ˆ: KR, VN)
  • State / Locality: ์ง€์—ญ ์ •๋ณด (์˜ˆ: Seoul)
  • Organization: ํšŒ์‚ฌ๋ช…/๋ถ€์„œ๋ช… (์˜ˆ: IT Team)
  • Common Name (CN): ์„œ๋น„์Šค ๋„๋ฉ”์ธ ์ฃผ์†Œ (๊ฐ€์žฅ ์ค‘์š”! ์˜ˆ: *.test.vn)
Note: ์ถ”๊ฐ€ ์ •๋ณด์ธ 'Challenge password' ๋“ฑ์€ ์ž…๋ ฅํ•˜์ง€ ์•Š๊ณ  Enter๋ฅผ ๋ˆŒ๋Ÿฌ ๋„˜์–ด๊ฐ€๋„ ๋ฌด๋ฐฉํ•ฉ๋‹ˆ๋‹ค.

3. ์‚ฌ์„ค ์ธ์ฆ์„œ(CRT) ์ƒ์„ฑ (Self-Signing)

์šฐ๋ฆฌ๋Š” ๊ณต์ธ ์ธ์ฆ ๊ธฐ๊ด€(VeriSign ๋“ฑ)์ด ์—†์œผ๋ฏ€๋กœ, ์ƒ์„ฑํ•œ CSR์— ๋‚ด ๊ฐœ์ธํ‚ค๋กœ ์ง์ ‘ ์„œ๋ช…(Self-Sign)ํ•˜์—ฌ ์ธ์ฆ์„œ(CRT)๋ฅผ ๋งŒ๋“ญ๋‹ˆ๋‹ค.

์ธ์ฆ์„œ ์ƒ์„ฑ

์œ ํšจ๊ธฐ๊ฐ„์„ 365์ผ๋กœ ์„ค์ •ํ•˜์—ฌ ์ตœ์ข… ์ธ์ฆ์„œ๋ฅผ ์ƒ์„ฑํ•ฉ๋‹ˆ๋‹ค.

# -req : CSR์„ ์ž…๋ ฅ๋ฐ›์Œ
# -signkey : ์Šค์Šค๋กœ ์„œ๋ช…ํ•  ํ‚ค ์ง€์ •
openssl x509 -req -days 365 -in test.vn.csr -signkey test.vn.key -out test.vn.crt

# ์„ฑ๊ณต ์‹œ ์ถœ๋ ฅ ๋ฉ”์‹œ์ง€
Signature ok
subject=/C=VN/ST=Hanoi/L=lotte/O=admin/OU=admin/CN=*.test.vn
Getting Private key

์ตœ์ข… ํŒŒ์ผ ํ™•์ธ

์ž‘์—…์ด ์™„๋ฃŒ๋˜๋ฉด ๋‹ค์Œ 3๊ฐœ์˜ ํŒŒ์ผ์ด ์žˆ์–ด์•ผ ํ•ฉ๋‹ˆ๋‹ค.

  • test.vn.key: ๊ฐœ์ธํ‚ค (ํŒจ์Šค์›Œ๋“œ ์ œ๊ฑฐ๋จ, ์„œ๋ฒ„ ์„ค์ •์— ์‚ฌ์šฉ)
  • test.vn.crt: ์ธ์ฆ์„œ (์„œ๋ฒ„ ์„ค์ •์— ์‚ฌ์šฉ)
  • test.vn.csr: ์‹ ์ฒญ์„œ (๋ฐœ๊ธ‰ ์™„๋ฃŒ ํ›„์—๋Š” ๋ถˆํ•„์š”)

4. Apache ์„ค์ • ๋ฐ ๊ฒ€์ฆ

์ƒ์„ฑ๋œ ํ‚ค์™€ ์ธ์ฆ์„œ๋ฅผ Apache ์„ค์ • ํŒŒ์ผ(httpd.conf ๋˜๋Š” ssl.conf)์— ๋“ฑ๋กํ•˜์—ฌ HTTPS๋ฅผ ํ™œ์„ฑํ™”ํ•ฉ๋‹ˆ๋‹ค.

์„ค์ • ์ ์šฉ

# SSL ์—”์ง„ ํ™œ์„ฑํ™”
SSLEngine on

# 1. ์ธ์ฆ์„œ ํŒŒ์ผ ๊ฒฝ๋กœ ์ง€์ • (.crt)
SSLCertificateFile /etc/httpd/conf/ssl/test.vn.crt

# 2. ๊ฐœ์ธํ‚ค ํŒŒ์ผ ๊ฒฝ๋กœ ์ง€์ • (.key)
SSLCertificateKeyFile /etc/httpd/conf/ssl/test.vn.key

๊ฒ€์ฆ (Verification)

Apache๋ฅผ ์žฌ๊ธฐ๋™ํ•˜๊ณ  ๋ธŒ๋ผ์šฐ์ €๋กœ ์ ‘์†ํ•ด ๋ด…๋‹ˆ๋‹ค. ํŒจ์Šค์›Œ๋“œ๋ฅผ ๋ฌป์ง€ ์•Š๊ณ  ๊ธฐ๋™๋˜์–ด์•ผ ์ •์ƒ์ž…๋‹ˆ๋‹ค.

  1. ์žฌ๊ธฐ๋™: systemctl restart httpd
  2. ๋ธŒ๋ผ์šฐ์ € ์ ‘์†: https://test.vn
์ฃผ์˜ (Warning):
์‚ฌ์„ค ์ธ์ฆ์„œ๋Š” ๋ธŒ๋ผ์šฐ์ €๊ฐ€ ์‹ ๋ขฐํ•˜๋Š” ๊ธฐ๊ด€(CA) ๋ชฉ๋ก์— ์—†์œผ๋ฏ€๋กœ, ์ ‘์† ์‹œ "์ฃผ์˜ ์š”ํ•จ" ๋˜๋Š” "์•ˆ์ „ํ•˜์ง€ ์•Š์Œ" ๊ฒฝ๊ณ ๊ฐ€ ๋œจ๋Š” ๊ฒƒ์ด ์ •์ƒ์ž…๋‹ˆ๋‹ค. ํ…Œ์ŠคํŠธ ํ™˜๊ฒฝ์—์„œ๋Š” ์˜ˆ์™ธ๋ฅผ ์ถ”๊ฐ€ํ•˜์—ฌ ์ง„ํ–‰ํ•˜๋ฉด ๋ฉ๋‹ˆ๋‹ค.

[JBoss/Apache] mod_cluster ์—ฐ๋™ ์™„๋ฒฝ ๊ฐ€์ด๋“œ: ๋™์  ํด๋Ÿฌ์Šคํ„ฐ๋ง ๋ฐ ๋ฉ€ํ‹ฐ์บ์ŠคํŠธ ์„ค์ •

JBoss EAP 6์™€ Apache HTTP Server๋ฅผ mod_cluster ๋ชจ๋“ˆ์„ ์‚ฌ์šฉํ•˜์—ฌ ์—ฐ๋™ํ•˜๋Š” ๋ฐฉ๋ฒ•์„ ์ •๋ฆฌํ•ฉ๋‹ˆ๋‹ค. ์ •์ ์ธ ์„ค์ • ์—†์ด๋„ WAS์˜ ์ถ”๊ฐ€/์‚ญ์ œ๋ฅผ ์ž๋™์œผ๋กœ ๊ฐ์ง€ํ•˜๋Š” ๋™์  ํด๋Ÿฌ์Šคํ„ฐ๋ง์„ ๊ตฌํ˜„ํ•˜๋ฉฐ, ๋ฉ€ํ‹ฐ์บ์ŠคํŠธ(Advertise) ์„ค์ •์„ ์ค‘์‹ฌ์œผ๋กœ ๋‹ค๋ฃน๋‹ˆ๋‹ค.

0. ์‚ฌ์ „ ์ค€๋น„ (Prerequisites)

  • OS: Windows 10 (ํ…Œ์ŠคํŠธ ํ™˜๊ฒฝ)
  • Web Server: Apache 2.2.x (JBoss EWS ํฌํ•จ ๋ฒ„์ „ ๊ถŒ์žฅ)
  • Middleware: JBoss EAP 6.4.x
๋ฒ„์ „ ํ˜ธํ™˜์„ฑ ์ฃผ์˜: Apache ๋ฒ„์ „์— ๋งž๋Š” mod_cluster ๋ชจ๋“ˆ(.so)์„ ์‚ฌ์šฉํ•ด์•ผ ํ•ฉ๋‹ˆ๋‹ค. JBoss EWS(Enterprise Web Server) ํŒจํ‚ค์ง€๋ฅผ ์‚ฌ์šฉํ•˜๋ฉด ์ด๋ฏธ ์ตœ์ ํ™”๋œ ๋ชจ๋“ˆ์ด ํฌํ•จ๋˜์–ด ์žˆ์Šต๋‹ˆ๋‹ค.

1. Apache ์„ค์ • (Web Server)

Apache์— mod_cluster ๊ด€๋ จ ๋ชจ๋“ˆ์„ ๋กœ๋“œํ•˜๊ณ , JBoss๊ฐ€ ๋ณด๋‚ธ ๋ฉ€ํ‹ฐ์บ์ŠคํŠธ ์‹ ํ˜ธ๋ฅผ ์ˆ˜์‹ ํ•  ์ˆ˜ ์žˆ๋„๋ก ์„ค์ •ํ•ฉ๋‹ˆ๋‹ค.

1) ํ•„์ˆ˜ ๋ชจ๋“ˆ ๋ณต์‚ฌ

JBoss EAP ์„ค์น˜ ๊ฒฝ๋กœ์— ํฌํ•จ๋œ mod_cluster ๊ด€๋ จ ๋ชจ๋“ˆ(.so)์„ Apache์˜ modules ๋””๋ ‰ํ† ๋ฆฌ๋กœ ๋ณต์‚ฌํ•ฉ๋‹ˆ๋‹ค.

  • ์›๋ณธ ์œ„์น˜: [EAP_HOME]/modules/system/layers/base/native/lib64/httpd/modules
  • ๋ณต์‚ฌํ•  ํŒŒ์ผ:
    • mod_advertise.so
    • mod_manager.so
    • mod_proxy_cluster.so
    • mod_slotmem.so

2) mod_cluster.conf ์ž‘์„ฑ

httpd.conf์—์„œ include ํ•  ์„ค์ • ํŒŒ์ผ์„ ์ž‘์„ฑํ•ฉ๋‹ˆ๋‹ค. ํ•ต์‹ฌ์€ VirtualHost ๋‚ด์˜ ServerAdvertise On ์„ค์ •์ž…๋‹ˆ๋‹ค.

# ํ•„์ˆ˜ ๋ชจ๋“ˆ ๋กœ๋“œ (์ˆœ์„œ ์ค‘์š”)
LoadModule slotmem_module modules/mod_slotmem.so
LoadModule manager_module modules/mod_manager.so
LoadModule proxy_cluster_module modules/mod_proxy_cluster.so
LoadModule advertise_module modules/mod_advertise.so

# ๊ณต์œ  ๋ฉ”๋ชจ๋ฆฌ ํŒŒ์ผ ์œ„์น˜ ์ง€์ •
MemManagerFile "C:/Apache/logs/mod_cluster"


  # JBoss ์ƒํƒœ ๊ด€๋ฆฌ ๋ฐ Advertise ์ˆ˜์‹  ํฌํŠธ
  Listen 6666
  
    
      Order deny,allow
      Deny from all
      Allow from 127.0.0.1  # ๋ณด์•ˆ์ƒ ๋กœ์ปฌ ์ ‘๊ทผ๋งŒ ํ—ˆ์šฉ ๊ถŒ์žฅ
    
    
    # ๋ฉ€ํ‹ฐ์บ์ŠคํŠธ ๊ด‘๊ณ  ํ™œ์„ฑํ™” (ํ•ต์‹ฌ)
    ServerAdvertise on
    EnableMCPMReceive

    # ๊ด€๋ฆฌ ์ฝ˜์†” URL
    
      SetHandler mod_cluster-manager
      Order deny,allow
      Allow from all
    
  

2. JBoss ์„ค์ • (Middleware)

JBoss๊ฐ€ ๊ธฐ๋™๋  ๋•Œ ์ž์‹ ์˜ ์ •๋ณด๋ฅผ ๋ฉ€ํ‹ฐ์บ์ŠคํŠธ๋กœ ์ „ํŒŒํ•˜๊ฑฐ๋‚˜, ํ”„๋ก์‹œ(Apache) ๋ฆฌ์ŠคํŠธ๋ฅผ ๋ฐ›์•„์˜ค๋„๋ก ์„ค์ •ํ•ฉ๋‹ˆ๋‹ค.

1) Instance ID ์„ค์ • (domain.xml)

Sticky Session์„ ์œ„ํ•ด ๊ฐ ์„œ๋ฒ„ ์ธ์Šคํ„ด์Šค์— ๊ณ ์œ ํ•œ ID๋ฅผ ๋ถ€์—ฌํ•ด์•ผ ํ•ฉ๋‹ˆ๋‹ค. ${jboss.server.name} ๋ณ€์ˆ˜๋ฅผ ์‚ฌ์šฉํ•˜๋ฉด ํŽธ๋ฆฌํ•ฉ๋‹ˆ๋‹ค.

<subsystem xmlns="urn:jboss:domain:web:2.2" default-virtual-server="default-host" instance-id="${jboss.server.name}" native="false">
    <connector name="http" protocol="HTTP/1.1" scheme="http" socket-binding="http"/>
    <connector name="ajp" protocol="AJP/1.3" scheme="http" socket-binding="ajp"/>
    ...
</subsystem>

2) ์†Œ์ผ“ ๋ฐ”์ธ๋”ฉ (Socket Binding) - ๋ฉ€ํ‹ฐ์บ์ŠคํŠธ ์ฃผ์†Œ

๋™์ผ ๋„คํŠธ์›Œํฌ ๋‚ด์— ์—ฌ๋Ÿฌ JBoss ํด๋Ÿฌ์Šคํ„ฐ๊ฐ€ ์กด์žฌํ•  ๊ฒฝ์šฐ ํ˜ผ์„ ์„ ๋ฐฉ์ง€ํ•˜๊ธฐ ์œ„ํ•ด ๋ฉ€ํ‹ฐ์บ์ŠคํŠธ ์ฃผ์†Œ๋‚˜ ํฌํŠธ๋ฅผ ๋ณ€๊ฒฝํ•ด์•ผ ํ•ฉ๋‹ˆ๋‹ค.

domain.xml ์ˆ˜์ • (socket-binding-group):

<socket-binding-group name="full-ha-sockets" default-interface="public">
    
    ...
</socket-binding-group>
Tip: XML์„ ์ˆ˜์ •ํ•˜์ง€ ์•Š๊ณ  ๊ธฐ๋™ ์‹œ ํŒŒ๋ผ๋ฏธํ„ฐ(System Property)๋กœ ์ฃผ์†Œ๋ฅผ ๋ณ€๊ฒฝํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.
-Djboss.modcluster.multicast.address=224.10.1.1

3. ๊ฒ€์ฆ ๋ฐ ํ…Œ์ŠคํŠธ

์„ค์ • ์™„๋ฃŒ ํ›„ Apache -> JBoss ์ˆœ์„œ๋กœ ๊ธฐ๋™ํ•ฉ๋‹ˆ๋‹ค.

1) Apache ๊ด€๋ฆฌ ์ฝ˜์†” ์ ‘์†

๋ธŒ๋ผ์šฐ์ €์—์„œ http://[Apache_IP]:6666/mod_cluster_manager ๋กœ ์ ‘์†ํ•ฉ๋‹ˆ๋‹ค.

  • ์ •์ƒ: ํ•˜๋‹จ์— ์—ฐ๊ฒฐ๋œ JBoss Node(Node Name, IP, Port) ๋ฆฌ์ŠคํŠธ๊ฐ€ ๋‚˜ํƒ€๋‚ฉ๋‹ˆ๋‹ค.
  • ์‹คํŒจ: ๋ฆฌ์ŠคํŠธ๊ฐ€ ๋น„์–ด์žˆ๋‹ค๋ฉด ๋ฉ€ํ‹ฐ์บ์ŠคํŠธ ํ†ต์‹ ์ด ๋ฐฉํ™”๋ฒฝ์— ๋ง‰ํ˜€์žˆ๊ฑฐ๋‚˜, Advertise ์„ค์ •์ด ์ž˜๋ชป๋œ ๊ฒƒ์ž…๋‹ˆ๋‹ค.

2) ํด๋Ÿฌ์Šคํ„ฐ๋ง ๋™์ž‘ ํ™•์ธ

์• ํ”Œ๋ฆฌ์ผ€์ด์…˜ ํ˜ธ์ถœ ์‹œ ์„ธ์…˜์ด ์œ ์ง€๋˜๋Š”์ง€ ํ™•์ธํ•˜๊ณ , ํ•œ ์ชฝ ๋…ธ๋“œ๋ฅผ ์…ง๋‹ค์šด ์‹œ์ผฐ์„ ๋•Œ Failover๊ฐ€ ์ผ์–ด๋‚˜๋Š”์ง€ ํ…Œ์ŠคํŠธํ•ฉ๋‹ˆ๋‹ค.

mod_cluster manager screen

[๊ทธ๋ฆผ] mod_cluster ๋งค๋‹ˆ์ € ํ™”๋ฉด (๋…ธ๋“œ ์ธ์‹ ์„ฑ๊ณต)


Next Step:
๋ฉ€ํ‹ฐ์บ์ŠคํŠธ ์‚ฌ์šฉ์ด ๋ถˆ๊ฐ€๋Šฅํ•œ ํด๋ผ์šฐ๋“œ ํ™˜๊ฒฝ์ด๋ผ๋ฉด, mod_cluster ์„ค์ •์„ TCP ์œ ๋‹ˆ์บ์ŠคํŠธ(Proxy List ์ง€์ • ๋ฐฉ์‹)๋กœ ๋ณ€๊ฒฝํ•˜์—ฌ ๊ตฌ์„ฑํ•˜๋Š” ๋ฐฉ๋ฒ•์„ ๊ฒ€ํ† ํ•ด ๋ณด์‹ญ์‹œ์˜ค.

[JBoss EAP 6] Windows Service ๋“ฑ๋ก ๊ฐ€์ด๋“œ (service.bat install)

Windows ํ™˜๊ฒฝ์—์„œ JBoss EAP 6๋ฅผ ๋ฐฑ๊ทธ๋ผ์šด๋“œ ์„œ๋น„์Šค๋กœ ๋“ฑ๋กํ•˜์—ฌ, ์‹œ์Šคํ…œ ๋ถ€ํŒ… ์‹œ ์ž๋™์œผ๋กœ ์‹œ์ž‘๋˜๋„๋ก ์„ค์ •ํ•˜๋Š” ๋ฐฉ๋ฒ•์„ ์ •๋ฆฌํ•ฉ๋‹ˆ๋‹ค. JBoss Native ํŒจํ‚ค์ง€์— ํฌํ•จ๋œ service.bat ์Šคํฌ๋ฆฝํŠธ๋ฅผ ์‚ฌ์šฉํ•ฉ๋‹ˆ๋‹ค.

0. ์‚ฌ์ „ ์ค€๋น„ (Prerequisites)

์„œ๋น„์Šค ๋“ฑ๋ก ์ž‘์—…์„ ์ˆ˜ํ–‰ํ•˜๊ธฐ ์œ„ํ•ด ๊ด€๋ฆฌ์ž ๊ถŒํ•œ(Run as Administrator)์œผ๋กœ ์‹คํ–‰๋œ ๋ช…๋ น ํ”„๋กฌํ”„ํŠธ(CMD)๊ฐ€ ํ•„์š”ํ•ฉ๋‹ˆ๋‹ค.

์‹œ์Šคํ…œ ํ™˜๊ฒฝ ๋ณ€์ˆ˜ ์„ค์ •

JBoss๊ฐ€ ์„œ๋น„์Šค๋กœ ๊ตฌ๋™๋  ๋•Œ ์ฐธ์กฐํ•  ํ•„์ˆ˜ ๋ณ€์ˆ˜๋ฅผ ์‹œ์Šคํ…œ ํ™˜๊ฒฝ ๋ณ€์ˆ˜์— ๋“ฑ๋กํ•ด์•ผ ํ•ฉ๋‹ˆ๋‹ค.

  • JBOSS_HOME: JBoss EAP 6 ์„ค์น˜ ๋””๋ ‰ํ† ๋ฆฌ (์˜ˆ: C:\jboss-eap-6.4)
  • NOPAUSE: ๊ฐ’์„ 1๋กœ ์„ค์ •.
    (※ ์ค‘์š”: ์ด ์„ค์ •์ด ์—†์œผ๋ฉด ์„œ๋น„์Šค ์ข…๋ฃŒ ์‹œ ๋ฐฐ์น˜ ์Šคํฌ๋ฆฝํŠธ๊ฐ€ "Press any key..." ์ƒํƒœ๋กœ ๋Œ€๊ธฐํ•˜์—ฌ ์„œ๋น„์Šค๊ฐ€ ์ •์ƒ์ ์œผ๋กœ ๋ฉˆ์ถ”์ง€ ์•Š๋Š” ๋ฌธ์ œ๊ฐ€ ๋ฐœ์ƒํ•ฉ๋‹ˆ๋‹ค.)

1. ์„œ๋น„์Šค ์„ค์น˜ ์Šคํฌ๋ฆฝํŠธ ์œ„์น˜

JBoss EAP 6๋Š” Windows ์„œ๋น„์Šค ๋“ฑ๋ก์„ ์œ„ํ•œ Native ์œ ํ‹ธ๋ฆฌํ‹ฐ๋ฅผ ๋‚ด์žฅํ•˜๊ณ  ์žˆ์Šต๋‹ˆ๋‹ค. ํ•ด๋‹น ๊ฒฝ๋กœ๋กœ ์ด๋™ํ•ฉ๋‹ˆ๋‹ค.

:: ๊ฒฝ๋กœ ์ด๋™ (์„ค์น˜ ํ™˜๊ฒฝ์— ๋”ฐ๋ผ ๊ฒฝ๋กœ๊ฐ€ ๋‹ค๋ฅผ ์ˆ˜ ์žˆ์Œ)
cd %JBOSS_HOME%\modules\system\layers\base\native\sbin

:: ํŒŒ์ผ ํ™•์ธ
dir service.bat

2. ์„œ๋น„์Šค ๋“ฑ๋ก (Install Command)

service.bat install ๋ช…๋ น์–ด๋ฅผ ์‚ฌ์šฉํ•ฉ๋‹ˆ๋‹ค. ์šด์˜ ๋ชจ๋“œ(Standalone / Domain)์— ๋”ฐ๋ผ ์˜ต์…˜์ด ๋‹ค๋ฆ…๋‹ˆ๋‹ค.

Case A: Standalone Mode (๋‹จ๋… ์ธ์Šคํ„ด์Šค)

๊ฐ€์žฅ ์ผ๋ฐ˜์ ์ธ ๊ตฌ์„ฑ์ž…๋‹ˆ๋‹ค. ๋กœ๊ทธ ๋ ˆ๋ฒจ์„ ์ง€์ •ํ•˜์—ฌ ์„ค์น˜ํ•ฉ๋‹ˆ๋‹ค.

service.bat install /loglevel INFO

Case B: Domain Mode (๋„๋ฉ”์ธ ๊ตฌ์„ฑ)

๋„๋ฉ”์ธ ์ปจํŠธ๋กค๋Ÿฌ(Domain Controller)์™€ ์—ฐ๊ฒฐํ•ด์•ผ ํ•˜๋ฏ€๋กœ ์ปจํŠธ๋กค๋Ÿฌ ์ •๋ณด๊ฐ€ ํ•„์š”ํ•ฉ๋‹ˆ๋‹ค.

:: ๊ธฐ๋ณธ ๊ตฌ๋ฌธ
service.bat install /controller [Host:Port] /host [HostName] /loglevel INFO

:: ์‚ฌ์šฉ ์˜ˆ์‹œ (๋กœ์ปฌ์ด ๋งˆ์Šคํ„ฐ์ธ ๊ฒฝ์šฐ)
service.bat install /controller localhost:9990 /host master /loglevel INFO

์ฃผ์š” ์˜ต์…˜ ์„ค๋ช…

์˜ต์…˜ ์„ค๋ช…
/name ์„œ๋น„์Šค ์ด๋ฆ„ ์ง€์ • (๊ธฐ๋ณธ๊ฐ’: JBossEAP6)
/desc ์„œ๋น„์Šค ์„ค๋ช… ์ง€์ •
/serviceuser ์„œ๋น„์Šค๋ฅผ ์‹คํ–‰ํ•  Windows ๊ณ„์ • (DOMAIN\User)
/servicepass ์‹คํ–‰ ๊ณ„์ •์˜ ์•”ํ˜ธ

3. ๋“ฑ๋ก ํ™•์ธ ๋ฐ ์ œ์–ด (Verification)

์„ค์น˜๊ฐ€ ์™„๋ฃŒ๋˜๋ฉด Windows ์„œ๋น„์Šค ๊ด€๋ฆฌ์ž์—์„œ ํ™•์ธํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

  1. ์‹คํ–‰ ์ฐฝ(Win+R) > services.msc ์ž…๋ ฅ.
  2. "JBoss Enterprise Application Platform 6" ์„œ๋น„์Šค๋ฅผ ์ฐพ์Šต๋‹ˆ๋‹ค.
  3. ์„œ๋น„์Šค๋ฅผ ์‹œ์ž‘(Start) ํ•˜๊ณ , ์ƒํƒœ๊ฐ€ '์‹คํ–‰ ์ค‘'์œผ๋กœ ๋ฐ”๋€Œ๋Š”์ง€ ํ™•์ธํ•ฉ๋‹ˆ๋‹ค.
  4. ๋ธŒ๋ผ์šฐ์ €๋กœ JBoss ๊ด€๋ฆฌ ์ฝ˜์†”์ด๋‚˜ ๋ฉ”์ธ ํŽ˜์ด์ง€์— ์ ‘์†ํ•˜์—ฌ ์‹ค์ œ ๊ตฌ๋™ ์—ฌ๋ถ€๋ฅผ ์ฒดํฌํ•ฉ๋‹ˆ๋‹ค.

4. ์„œ๋น„์Šค ์‚ญ์ œ (Uninstall)

์„ค์ •์„ ๋ณ€๊ฒฝํ•˜๊ฑฐ๋‚˜ ๊ฒฝ๋กœ๋ฅผ ๋ฐ”๊ฟ€ ๊ฒฝ์šฐ, ๊ธฐ์กด ์„œ๋น„์Šค๋ฅผ ์‚ญ์ œํ•˜๊ณ  ๋‹ค์‹œ ๋“ฑ๋กํ•ด์•ผ ํ•ฉ๋‹ˆ๋‹ค.

:: ์„œ๋น„์Šค ์ค‘์ง€ (๋จผ์ € ์ˆ˜ํ–‰ ํ•„์ˆ˜)
service.bat stop

:: ์„œ๋น„์Šค ์‚ญ์ œ
service.bat uninstall
์ฃผ์˜: ์„œ๋น„์Šค ์‚ญ์ œ ํ›„ services.msc ๋ชฉ๋ก์— ์ž”์ƒ์ด ๋‚จ์•„์žˆ๋‹ค๋ฉด, ์œˆ๋„์šฐ๋ฅผ ์žฌ๋ถ€ํŒ…ํ•˜๊ฑฐ๋‚˜ ๊ด€๋ฆฌ์ž ๊ถŒํ•œ CMD์—์„œ sc delete [์„œ๋น„์Šค๋ช…]์„ ๊ฐ•์ œ๋กœ ์ˆ˜ํ–‰ํ•ด์•ผ ํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

[IHS/Apache] ๋ณด์•ˆ ๊ฐ•ํ™”๋ฅผ ์œ„ํ•œ ๋ถˆํ•„์š” HTTP Method(PUT, DELETE, TRACE) ์ฐจ๋‹จ ์„ค์ •

์›น ์„œ๋ฒ„ ์šด์˜ ์‹œ ๋ณด์•ˆ ์ทจ์•ฝ์ (ํŒŒ์ผ ๋ณ€์กฐ, ์ •๋ณด ๋…ธ์ถœ ๋“ฑ)์„ ๋ฐฉ์ง€ํ•˜๊ธฐ ์œ„ํ•ด GET, POST๋ฅผ ์ œ์™ธํ•œ ๋ถˆํ•„์š”ํ•œ HTTP Method(PUT, DELETE, TRACE, OPTIONS)๋ฅผ ์ฐจ๋‹จํ•˜๋Š” ๋ฐฉ๋ฒ•์„ ์ •๋ฆฌํ•ฉ๋‹ˆ๋‹ค. IBM HTTP Server(Apache) ์„ค์ •๊ณผ WAS(web.xml) ์„ค์ • ๋‘ ๊ฐ€์ง€ ๋ฐฉ์‹์„ ๋‹ค๋ฃน๋‹ˆ๋‹ค.

0. ๋ฐฐ๊ฒฝ ์ง€์‹ (Context)

๊ธฐ๋ณธ์ ์œผ๋กœ ์›น ์„œ๋ฒ„๋Š” ๋‹ค์–‘ํ•œ HTTP Method๋ฅผ ์ง€์›ํ•˜์ง€๋งŒ, ์‹ค์ œ ์„œ๋น„์Šค์—์„œ๋Š” ๋Œ€๋ถ€๋ถ„ GET๊ณผ POST๋งŒ ์‚ฌ์šฉํ•ฉ๋‹ˆ๋‹ค. ๋ถˆํ•„์š”ํ•œ ๋ฉ”์†Œ๋“œ๋ฅผ ์—ด์–ด๋‘˜ ๊ฒฝ์šฐ ๋‹ค์Œ๊ณผ ๊ฐ™์€ ๋ณด์•ˆ ์œ„ํ—˜์ด ์žˆ์Šต๋‹ˆ๋‹ค.

  • PUT, DELETE: ์•…์˜์ ์ธ ์‚ฌ์šฉ์ž๊ฐ€ ์„œ๋ฒ„์˜ ํŒŒ์ผ์„ ์ƒ์„ฑ, ์ˆ˜์ •, ์‚ญ์ œํ•  ์ˆ˜ ์žˆ์Œ.
  • TRACE: XST(Cross-Site Tracing) ๊ณต๊ฒฉ์— ์•…์šฉ๋˜์–ด ์ฟ ํ‚ค/์„ธ์…˜ ์ •๋ณด๊ฐ€ ํƒˆ์ทจ๋  ์ˆ˜ ์žˆ์Œ.
  • OPTIONS: ์„œ๋ฒ„๊ฐ€ ์ง€์›ํ•˜๋Š” ๋ฉ”์†Œ๋“œ ์ •๋ณด๋ฅผ ๋…ธ์ถœํ•จ.

Test Environment

  • OS: CentOS 7.2
  • Web Server: IBM HTTP Server v8.5 (Apache 2.2 Base)

1. Web Server ๋ ˆ๋ฒจ ์ฐจ๋‹จ (httpd.conf)

๊ฐ€์žฅ ์•ž๋‹จ์˜ ์›น ์„œ๋ฒ„์—์„œ ์›์ฒœ ์ฐจ๋‹จํ•˜๋Š” ๊ฒƒ์ด ๋ฆฌ์†Œ์Šค ๋‚ญ๋น„๋ฅผ ๋ง‰๊ณ  ์•ˆ์ „ํ•ฉ๋‹ˆ๋‹ค. ๋‘ ๊ฐ€์ง€ ๋ฐฉ๋ฒ• ์ค‘ ํ•˜๋‚˜๋ฅผ ์„ ํƒํ•˜์—ฌ ์ ์šฉํ•˜์‹ญ์‹œ์˜ค.

Method A: LimitExcept ์ง€์‹œ์–ด ์‚ฌ์šฉ (๊ถŒ์žฅ)

ํŠน์ • ๋””๋ ‰ํ† ๋ฆฌ๋‚˜ URL ํŒจํ„ด์— ๋Œ€ํ•ด ํ—ˆ์šฉํ•  ๋ฉ”์†Œ๋“œ๋ฅผ ์ •์˜ํ•˜๊ณ  ๋‚˜๋จธ์ง€๋Š” ๊ฑฐ๋ถ€ํ•˜๋Š” ๋ฐฉ์‹์ž…๋‹ˆ๋‹ค.

# 1. ํŠน์ • ๋””๋ ‰ํ† ๋ฆฌ ๊ธฐ์ค€ ์ฐจ๋‹จ
<Directory "/WAS/htdocs">
    Options FollowSymLinks
    AllowOverride None
    
    # GET, POST๋ฅผ ์ œ์™ธํ•œ ๋ชจ๋“  ๋ฉ”์†Œ๋“œ ๊ฑฐ๋ถ€
    <LimitExcept GET POST>
        Order allow,deny
        Deny from all
    </LimitExcept>
</Directory>

# 2. ์ „์—ญ(URL) ๊ธฐ์ค€ ์ฐจ๋‹จ (Directory ์„ค์ •์ด ๋ชจํ˜ธํ•  ๋•Œ)
<Location "/*">
    <LimitExcept GET POST>
        Order allow,deny
        Deny from all
    </LimitExcept>
</Location>
๋ฒ„์ „๋ณ„ ๋ฌธ๋ฒ• ์ฃผ์˜ (Note):
IHS v8.5(Apache 2.2)๋Š” Order/Deny๋ฅผ ์‚ฌ์šฉํ•˜์ง€๋งŒ, IHS v9.0(Apache 2.4) ์ด์ƒ์—์„œ๋Š” Require all denied ๋ฌธ๋ฒ•์„ ์‚ฌ์šฉํ•ด์•ผ ํ•ฉ๋‹ˆ๋‹ค.

Method B: Mod_Rewrite ์‚ฌ์šฉ

mod_rewrite ๋ชจ๋“ˆ์„ ์‚ฌ์šฉํ•˜์—ฌ ๋ฉ”์†Œ๋“œ ์กฐ๊ฑด์„ ๊ฒ€์‚ฌํ•˜๊ณ  ๊ฐ•์ œ๋กœ ์—๋Ÿฌ ์ฝ”๋“œ๋ฅผ ๋ฐ˜ํ™˜ํ•˜๋Š” ๋ฐฉ์‹์ž…๋‹ˆ๋‹ค.

LoadModule rewrite_module modules/mod_rewrite.so

<IfModule mod_rewrite.c>
    RewriteEngine On
    
    # ์กฐ๊ฑด: ์š”์ฒญ ๋ฉ”์†Œ๋“œ๊ฐ€ GET ๋˜๋Š” POST๊ฐ€ ์•„๋‹ˆ๋ผ๋ฉด
    RewriteCond %{REQUEST_METHOD} !^(GET|POST)
    
    # ๊ทœ์น™: 405 (Method Not Allowed) ์—๋Ÿฌ ๋ฐ˜ํ™˜
    RewriteRule .* - [R=405,L]
</IfModule>

2. WAS ๋ ˆ๋ฒจ ์ฐจ๋‹จ (web.xml)

์›น ์„œ๋ฒ„ ์„ค์ •์ด ๋ถˆ๊ฐ€๋Šฅํ•˜๊ฑฐ๋‚˜, ์• ํ”Œ๋ฆฌ์ผ€์ด์…˜(WAR) ๋‹จ์œ„๋กœ ์ œ์–ด๊ฐ€ ํ•„์š”ํ•œ ๊ฒฝ์šฐ ํ‘œ์ค€ ๋ฐฐํฌ ์„œ์ˆ ์ž(web.xml)๋ฅผ ์‚ฌ์šฉํ•ฉ๋‹ˆ๋‹ค.

์„ค์ • ๋ฐฉ๋ฒ•

web.xml์— security-constraint๋ฅผ ์ถ”๊ฐ€ํ•˜์—ฌ ํŠน์ • ๋ฉ”์†Œ๋“œ์— ๋Œ€ํ•œ ์ ‘๊ทผ์„ ์ œํ•œํ•ฉ๋‹ˆ๋‹ค.

<security-constraint>
    <web-resource-collection>
        <web-resource-name>Restricted Methods</web-resource-name>
        <url-pattern>/*</url-pattern>
        
        <!-- ์ฐจ๋‹จํ•  ๋ฉ”์†Œ๋“œ ๋ช…์‹œ -->
        <http-method>PUT</http-method>
        <http-method>DELETE</http-method>
        <http-method>TRACE</http-method>
        <http-method>OPTIONS</http-method>
        <http-method>HEAD</http-method>
    </web-resource-collection>
    
    <!-- ์ค‘์š”: auth-constraint๋ฅผ ๋น„์›Œ๋‘๋ฉด ๋ˆ„๊ตฌ์—๊ฒŒ๋„ ๊ถŒํ•œ์„ ์ฃผ์ง€ ์•Š์Œ(์ฐจ๋‹จ) -->
    <auth-constraint />
</security-constraint>

3. ๊ฒ€์ฆ (Verification)

์„ค์ • ์ ์šฉ ํ›„ ๋ฐ˜๋“œ์‹œ ํ…Œ์ŠคํŠธ๋ฅผ ํ†ตํ•ด ์ฐจ๋‹จ ์—ฌ๋ถ€๋ฅผ ํ™•์ธํ•ด์•ผ ํ•ฉ๋‹ˆ๋‹ค. telnet ๋˜๋Š” curl์„ ์‚ฌ์šฉํ•ฉ๋‹ˆ๋‹ค.

Telnet์„ ์ด์šฉํ•œ ํ…Œ์ŠคํŠธ

$ telnet localhost 80
Trying ::1...
Connected to localhost.
Escape character is '^]'.

# OPTIONS ๋ฉ”์†Œ๋“œ ์š”์ฒญ ์ž…๋ ฅ
OPTIONS / HTTP/1.0
Host: localhost
(์—”ํ„ฐ ๋‘ ๋ฒˆ)

# ๊ฒฐ๊ณผ ํ™•์ธ (403 Forbidden ๋˜๋Š” 405 Method Not Allowed ํ™•์ธ)
HTTP/1.1 403 Forbidden
Date: Wed, 04 Jul 2018 01:44:40 GMT
...

Curl์„ ์ด์šฉํ•œ ํ…Œ์ŠคํŠธ (๊ฐ„ํŽธ)

# -X ์˜ต์…˜์œผ๋กœ ๋ฉ”์†Œ๋“œ ์ง€์ •, -I ์˜ต์…˜์œผ๋กœ ํ—ค๋”๋งŒ ํ™•์ธ
curl -v -X OPTIONS http://localhost/

# ๊ฒฐ๊ณผ: < HTTP/1.1 403 Forbidden ํ™•์ธ

Next Step:
๋ฉ”์†Œ๋“œ ์ฐจ๋‹จ ์™ธ์—๋„ ServerTokens Prod ์„ค์ •์„ ํ†ตํ•ด ํ—ค๋”์— ๋…ธ์ถœ๋˜๋Š” ์›น ์„œ๋ฒ„ ๋ฒ„์ „ ์ •๋ณด๋ฅผ ์ˆจ๊ธฐ๋Š” ๋ณด์•ˆ ์กฐ์น˜๋ฅผ ์ถ”๊ฐ€๋กœ ๊ฒ€ํ† ํ•ด ๋ณด์‹œ๊ธฐ ๋ฐ”๋ž๋‹ˆ๋‹ค.

[IBM HTTP Server ] IBM HTTP Server v8.5 vs v9.0: Apache Base Version ํ™•์ธ ๋ฐ ์ฐจ์ด์  (Apache 2.2 vs 2.4)

IBM HTTP Server(IHS)๋Š” Apache HTTP Server๋ฅผ ๊ธฐ๋ฐ˜์œผ๋กœ ๋งŒ๋“ค์–ด์กŒ์Šต๋‹ˆ๋‹ค. IHS v8.5(Apache 2.2 ๊ธฐ๋ฐ˜)์™€ IHS v9.0(Apache 2.4 ๊ธฐ๋ฐ˜)์˜ ๋ฒ„์ „ ์ •๋ณด๋ฅผ ํ™•์ธํ•˜๊ณ , ์—”์ง„ ์—…๊ทธ๋ ˆ์ด๋“œ์— ๋”ฐ๋ฅธ ์„ค์ • ํŒŒ์ผ(httpd.conf) ํ˜ธํ™˜์„ฑ ์ฃผ์˜์‚ฌํ•ญ์„ ์ •๋ฆฌํ•ฉ๋‹ˆ๋‹ค.

1. ๋ฒ„์ „ ํ™•์ธ ๋ฐฉ๋ฒ• (Check Version)

IHS์˜ ์‹คํ–‰ ํŒŒ์ผ(apache.exe ๋˜๋Š” httpd)์— -V ์˜ต์…˜์„ ์ฃผ์–ด ์ปดํŒŒ์ผ ์˜ต์…˜๊ณผ ๊ธฐ๋ฐ˜ ๋ฒ„์ „์„ ํ™•์ธํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

๋ช…๋ น์–ด

# Windows
cd [IHS_HOME]\bin
.\apache.exe -V

# Linux/Unix
cd [IHS_HOME]/bin
./apachectl -V

2. ๋ฒ„์ „๋ณ„ ์ƒ์„ธ ์ •๋ณด (Output Analysis)

IHS v8.5 (Apache 2.2 Base)

IHS 8.5.5๋Š” Apache 2.2.8 ๋ฒ„์ „์„ ๋ฒ ์ด์Šค๋กœ ํ•˜์—ฌ IBM์˜ ์ถ”๊ฐ€์ ์ธ ํŒจ์น˜์™€ ๋ณด์•ˆ ์ˆ˜์ •์ด ์ ์šฉ๋œ ๋ฒ„์ „์ž…๋‹ˆ๋‹ค.

PS E:\app\was\HTTPServer\bin> .\apache.exe -V
Server version: IBM_HTTP_Server/8.5.5.0 (Win32)
Apache version: 2.2.8 (with additional fixes)  <-- Check Point
Server built:   Feb 20 2013 13:50:05
Architecture:   32-bit
Server MPM:     WinNT
  threaded:     yes (fixed thread count)
  forked:       no
Server compiled with....
 -D APACHE_MPM_DIR="server/mpm/winnt"
 -D APR_HAS_SENDFILE
 -D APR_HAS_MMAP
 -D HTTPD_ROOT="/apache"
 -D SERVER_CONFIG_FILE="conf/httpd.conf"

IHS v9.0 (Apache 2.4 Base)

IHS 9.0์€ Apache 2.4.12 ๋ฒ„์ „์„ ๋ฒ ์ด์Šค๋กœ ํ•ฉ๋‹ˆ๋‹ค. Apache 2.4๋กœ ๋„˜์–ด์˜ค๋ฉด์„œ ์„ฑ๋Šฅ ๊ฐœ์„ (Event MPM ๋“ฑ)๊ณผ ์„ค์ • ๋ฌธ๋ฒ•์˜ ๋ณ€ํ™”๊ฐ€ ์ƒ๊ฒผ์Šต๋‹ˆ๋‹ค.

PS E:\software\IBM\HTTPServer9\bin> .\apache.exe -V
Server version: IBM_HTTP_Server/9.0.0.0-PI56034 (Win32)
Apache version: 2.4.12 (with additional fixes) <-- Check Point
Server built:   Apr 18 2016 20:28:53
Architecture:   32-bit
Server MPM:     WinNT
  threaded:     yes (fixed thread count)
  forked:       no
Server compiled with....
 -D APR_HAS_SENDFILE
 -D APR_HAS_MMAP
 -D DYNAMIC_MODULE_LIMIT=256
 -D HTTPD_ROOT="/apache"
 -D SERVER_CONFIG_FILE="conf/httpd.conf"

3. ๋งˆ์ด๊ทธ๋ ˆ์ด์…˜ ์ฃผ์˜์‚ฌํ•ญ (Apache 2.2 vs 2.4)

IHS v8.5์—์„œ v9.0์œผ๋กœ ์—…๊ทธ๋ ˆ์ด๋“œํ•  ๋•Œ ๊ฐ€์žฅ ์ฃผ์˜ํ•ด์•ผ ํ•  ์ ์€ ์ ‘๊ทผ ์ œ์–ด(Access Control) ๊ตฌ๋ฌธ์˜ ๋ณ€ํ™”์ž…๋‹ˆ๋‹ค. ๊ธฐ์กด httpd.conf๋ฅผ ๊ทธ๋Œ€๋กœ ์‚ฌ์šฉํ•˜๋ฉด ์—๋Ÿฌ๊ฐ€ ๋ฐœ์ƒํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

์ฃผ์š” ๋ณ€๊ฒฝ ์  ๋น„๊ต

๊ตฌ๋ถ„ IHS v8.5 (Apache 2.2) IHS v9.0 (Apache 2.4)
๋ชจ๋“  ์š”์ฒญ ํ—ˆ์šฉ Order allow,deny
Allow from all
Require all granted
๋ชจ๋“  ์š”์ฒญ ๊ฑฐ๋ถ€ Order deny,allow
Deny from all
Require all denied
ํŠน์ • IP ํ—ˆ์šฉ Order deny,allow
Deny from all
Allow from 127.0.0.1
Require ip 127.0.0.1
Warning: IHS 9.0์—์„œ ๊ธฐ์กด 2.2 ๋ฌธ๋ฒ•(Order/Allow)์„ ์‚ฌ์šฉํ•˜๋ ค๋ฉด mod_access_compat ๋ชจ๋“ˆ์„ ๋กœ๋“œํ•ด์•ผ ํ•ฉ๋‹ˆ๋‹ค. ํ•˜์ง€๋งŒ ์žฅ๊ธฐ์ ์œผ๋กœ๋Š” ์‹ ๊ทœ ๋ฌธ๋ฒ•(Require)์œผ๋กœ ์ „ํ™˜ํ•˜๋Š” ๊ฒƒ์„ ๊ถŒ์žฅํ•ฉ๋‹ˆ๋‹ค.

Next Step:
IHS ๋ฒ„์ „์„ ์—…๊ทธ๋ ˆ์ด๋“œํ•  ๊ณ„ํš์ด๋ผ๋ฉด, ์šด์˜ ์ค‘์ธ httpd.conf ํŒŒ์ผ ๋‚ด์˜ ์ ‘๊ทผ ์ œ์–ด ๊ตฌ๋ฌธ์„ ๋ฏธ๋ฆฌ ์ „์ˆ˜ ์กฐ์‚ฌํ•˜์—ฌ Apache 2.4 ๋ฌธ๋ฒ•์œผ๋กœ ๋ณ€ํ™˜ํ•˜๋Š” ์ž‘์—…์„ ์ง„ํ–‰ํ•ด ๋ณด์‹ญ์‹œ์˜ค.