RED5 & FFMPEG & FFserver 스트리밍 서버 구축하기

 

http://blog.syszone.co.kr/2498?category=17

 

작성자 : 서진우(alang@syszone.co.kr)
작성일 : 2009년 1월 5일

4.1 FFMPEG로 인코딩 환경 구축하기
– 기본 프로그램 설치
# yum install ruby
# yum install ncurses-devel*
# yum install lame
# yum install libogg
# yum install libvorbis
# yum install flvtool2
# yum install ffmpeg
– 코덱 설치
# wget http://www3.mplayerhq.hu/MPlayer/releases/codecs/essential-20061022.tar.bz2
# bunzip2 essential-20061022.tar.bz2
# tar xvf essential-20061022.tar
# mkdir /usr/local/lib/codecs/
# mv essential-20061022/* /usr/local/lib/codecs/
# chmod -R 755 /usr/local/lib/codecs/
# vi /etc/ld.so.conf
# ldconfig
– ffmpeg 기본 사용법
AVI -> FLV
# ffmpeg -i onestar.avi -ar 22050 -ab 32 -f flv -s 640×480 onestar.flv | flvtool2 -U stdin onestar.flv
-i             : input file name
-ar          : audio sampling rate in HZ
-ab          : audio bit rate in kbit/s
-f             : output format
-s             : output dimension
FLV -> JPG
# ffmpeg -i test.flv -an -r 1 -y -s 640×480 test%d.jpg
-i             : input file name
-an         : disable audio
-r            : fps
-y           : overwrite file
-s            : output dimension
Particular frame to JPG
# ffmpeg -i test.flv -an -ss 00:00:10 -t 00:00:01 -r 1 -y -s 640×480 test%d.jpg
-ss          : recored start time
-t            : record end time last for
– ffmpeg 실무 사용법
ffmpeg를 이용하여 avi 파일을 flv로 변환 한다.
# ffmpeg -i onestar.avi -b 512k -ar 22050 -ab 128k -r 24 -s 400×300 onestar.flv
or
# ffmpeg -i “onestar.avi” -vcodec flv -f flv -r 29.97 -s 400×300 -aspect 4:3 -b 320k -g 160 -cmp 2 -subcmp 2 -mbd 2 -flags +aic+cbp+mv0+mv4+trell -ac 1 -ar 22050 -ab 128k “onestar.flv”
– FLV에 메타데이터 넣기 (스트리밍 보기-중간 구간 바로 보기)
# flvtool2 -U onstar.flv
– 동영상 썸네일 만들기
# ffmpeg -y -i onestar.avi -vframes 1 -ss 00:00:02 -an -vcodec png -f rawvideo -s 400×300 onestar.png
# ffmpeg  -itsoffset -4  -i test.avi -vcodec mjpeg -vframes 1 -an -f rawvideo -s 320×240 test.jpg
– 동영상에 자막 넣기
동영상을 flv 로 변환할때 자막을 같이 넣을 경우 기존의 ffmpeg로는 자막 포함 기능이
제공되지 않는다. 자막을 포함하여 인코딩을 할 수 있는 프로그램으로 mencoder이 있다.
설치는 yum으로 쉽게 가능하다.
# yum install mencoder
설치 후 자막의 언어 설정을 아래와 같이 한다.
$ vi ~/.mplayer/mencoder.conf
————————————————————————-
font=”/usr/share/fonts/korean/TrueType/gulim.ttf”
subfont-text-scale=3
subcp=cp949
————————————————————————-
이제 mencoder로 자막을 포함해서 인코딩을 한다.
$ mencoder -noodml [avi파일]  -o [flv파일]  -sub $1.smi -of lavf -oac mp3lame -lameopts abr:br=128 -ovc lavc -lavcopts vcodec=flv:vbitrate=512:mbd=2:mv0:trell:v4mv:cbp:last_pred=3 -srate 44100 -lavfopts i_certify_that_my_video_stream_does_not_use_b_frames -vf-add scale=400:300

– 웹 FLV_Player 연동하기
웹에서 FLV 파일을 스트리밍으로 볼수 있는 Player는 여러가지가 있다.
* UCCUP에서 제공하는 Player –
http://www.uccup.kr
* http://flowplayer.org/download.html
* GRZ_JWMediaPlayer
– UCCUP Player 연동하기
아래 구문중 flv 파일명과 png 파일명을 수정 후 HTML 문서에 붙여 넣는다.
flv,png 파일은 [UCCUP설치경로]/SERVICE 디렉토리 밑에 복사해 둔다.
<embed src=”
http://syszone.co.kr/uccup/UCCUp.swf?file=http://syszone.co.kr/uccup/file.php?f=onestar.flv&previewImage=http://syszone.co.kr/uccup/file.php?f=onestar.png&bufferTime=3&bgColor=-1
width=”400″ height=”300″ scale=”noscale” bgcolor=”#ffffff” type=”application/x-shockwave-flash” allowFullScreen=”true”
allowScriptAccess=”always” allowNetworking=”all” pluginspage=”
http://www.macromedia.com/go/getflashplayer“>
</embed>
– GRZ_JWMediaPlayer 연동하기
아래는 textcube의 플러그인으로 연동된 GRZ_JWMediaPlayer를 이용하는 방법이다.
<object classid=”clsid:d27cdb6e-ae6d-11cf-96b8-444553540000″ codebase=”
http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=7,0,0,0” width=”425″ height=”340″>
<param name=”movie” value=”/plugins/GRZ_JWMediaPlayer/mediaplayer.swf”/>
<param name=”allowfullscreen” value=”true”/>
<param name=”wmode” value=”transparent”/>
<param name=”flashvars” value=”width=425&height=340&thumbsinplaylist=true&displayheight=320&overstretch=true&logo=&searchbar=false&linkfromdisplay=true&linktarget=_blank&file=/plugins/GRZ_JWMediaPlayer/mkpl.php?list=1|%5bhttp%5dblog.syszone.co.kr%2fattach%2f1%2f1466599573.flv|alang.flv+%289.64+MB%29|||||%5bhttp%5dblog.syszone.co.kr|”/>
<!–[if !IE]> <–>
<object type=”application/x-shockwave-flash” transparent=”yes” data=”/plugins/GRZ_JWMediaPlayer/mediaplayer.swf” flashvars=”thumbsinplaylist=true&displayheight=320&overstretch=true&logo=&searchbar=false&linkfromdisplay=true&linktarget=_blank&file=/plugins/GRZ_JWMediaPlayer/mkpl.php?list=1|%5bhttp%5dblog.syszone.co.kr%2fattach%2f1%2f1466599573.flv|alang.flv+%289.64+MB%29|||||%5bhttp%5dblog.syszone.co.kr|” width=”425″ height=”340″>
<p>
<a href=”/plugins/GRZ_JWMediaPlayer/mediaplayer.swf”>[Flash]</a></p>
</object>
<!–> <![endif]–>
</object>
– FlowPlayer 연동하기
기본 연동법
————————————————————————————
<object type=”application/x-shockwave-flash” data=”[your site]/FlowPlayer.swf”
width=”320″ height=”263″ id=”FlowPlayer”>
<param name=”allowScriptAccess” value=”sameDomain”/>
<param name=”movie” value=”[your site]/FlowPlayer.swf”/>
<param name=”quality” value=”high”/>
<param name=”scale” value=”noScale”/>
<param name=”wmode” value=”transparent”/>
<param name=”flashvars” value=”baseURL=[base URL]&amp;videoFile=movie.flv
&amp;autoPlay=false&amp;loop=false&amp;autoBuffering=false
&amp;splashImageFile=movie.png”/>
</object>
————————————————————————————–
or
————————————————————————————–
<script type=”text/javascript” src=”flowplayer-3.0.2.min.js”></script>
<script>
flowplayer(“player”, “./flowplayer-3.0.2.swf”);
</script>
<a href=”
http://syszone.co.kr/yaejin/data/11.flv” style=”display:block;width:400px;height:300px” id=”player”>
</a>
————————————————————————————–
or
————————————————————————————–
<script type=”text/javascript” src=”flowplayer-3.0.2.min.js”></script>
<script>
flowplayer(“player”, “./flowplayer-3.0.2.swf”, {
clip: {
url: ‘http://syszone.co.kr/yaejin/data/11.flv’,
autoPlay: false,

        onStart: function(clip) {
pageTracker._trackPageview(“configuration demo: ” + clip.url);
}
}

});
</script>
<a href=”
http://syszone.co.kr/yaejin/data/11.flv” style=”display:block;width:400px;height:300px” id=”player”>
<img src=”
http://syszone.co.kr/yaejin/data/11.png” border=0 alt=”Play this video” />
</a>
—————————————————————————————
or (youtube 방식의 동영상 라이브러리 구현)
—————————————————————————————
<!DOCTYPE html PUBLIC “-//W3C//DTD XHTML 1.0 Transitional//EN”
http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd“>
<c:if test=”true”>
<!– include desired tools –>
<script src=”
http://syszone.co.kr/yaejin/jquery.min.js”></script>
<script src=”
http://syszone.co.kr/yaejin/flowplayer-3.0.2.min.js”></script>
</c:if>
<script src=”
http://syszone.co.kr/yaejin/flowplayer.playlist-3.0.1.min.js”></script>
<!– player / playlist styling –>
<style>
/* player style */
/* container has a background image */
a.player {
margin-top:40px;
display:block;
background:url(
http://syszone.co.kr/yaejin/img/splash.png) no-repeat;
width:425px;
height:298px;
padding:0 126px 75px 127px;
text-align:center;
color:#fff;
text-decoration:none;
cursor:pointer;
}
/* splash image */
a.player img {
margin-top:115px;
border:0;
}

#player {
float:left;
}
/* playlist style */
#playlist {
width:300px;
height:380px;
overflow-y:auto;
overflow-x:hidden;
border:1px solid #ccc;
padding:4px 10px 12px 10px;
background-color:#efefef;
margin-top:20px;
float:left;
}
/* playlist entry */
#playlist a {
display:block;
width:260px;
height:60px;
padding:7px;
background-color:#fff;
border:1px solid #ccc;
font:11px “bitstream vera sans”, “lucida grande”,verdana;
text-decoration:none;
margin-top:7px;
color:#666;
}
/* different states of a playlist entry */
#playlist a:hover {
background-color:#ffc;
}
#playlist a.progress {
background-color:#efefef;
}
#playlist a.playing {
border:1px solid #666;
background-color:#ffc;
}
#playlist a.paused {
border:1px solid #666;
background-color:#ffc;
}
/* elements inside playlist entry */
#playlist a img {
border:0;
float:left;
margin-right:10px;
}
#playlist a strong {
color:blue;
padding-bottom:5px;
}
#playlist a em {
border:0;
float:left;
margin-right:10px;
background:url(
http://syszone.co.kr/yaejin/img/clock.gif) no-repeat 0 50%;
padding-left:20px;
color:#333;
font-style:normal;
margin-top:10px;
}
</style>

<!– javascript setup. pretty simple stuff –>
<script>
$(function() {
// setup player
$f(“player”, “flowplayer-3.0.2.swf”, {
clip: {baseUrl: ‘http://syszone.co.kr/yaejin/data’}
// playlist plugin
}).playlist(“#playlist”);
});
</script>

<!– player container –>
<a id=”player” class=”player plain”>
<img src=”
http://syszone.co.kr/yaejin/img/play.png” />
</a>
<!– the playlist. simple HTML controlled with CSS –>
<div id=”playlist”>
<a href=071202-탄생1.flv>
<img src=http://syszone.co.kr/yaejin/data/071202-탄생1.png />
<strong>071202-탄생1</strong><br /><br>
</a>
<a href=071202-탄생2.flv>
<img src=http://syszone.co.kr/yaejin/data/071202-탄생2.png />
<strong>071202-탄생2</strong><br /><br>
</a>
.
.
</div>
<!– let the rest of the page float normally –>
<br clear=”all” />
————————————————————————————

– Encoding 관련 스크립트 제작
ffmpeg를 이용하여 avi 파일을 flv로 변환하는 스크립트
# vi /usr/bin/ffmpeg_encoder.sh [filename] [geometry]
———————————————————————————–
#!/bin/sh
if [ $# -lt 2 ]
then
echo -n “using : ffmpeg_encoder.sh <filename> <geometry> ( movie 400×300 )
“;
exit;
fi
ffmpeg -i $1.avi -b 512k -ar 22050 -r 24 -ab 128k -s $2 $1.flv
ffmpeg -y -i $1.avi -vframes 1 -ss 00:00:02 -an -vcodec png -f rawvideo -s $2 $1.png
flvtool2 -U $1.flv
echo -n “——————————————————–
$1.avi completed $1.flv to encoding..!!
——————————————————–
“;
———————————————————————————-
mencoder를 이용하여 avi파일과 smi 자막파일을 flv 파일로 변환하는 스크립트
# vi /usr/bin/mencoder_encoder.sh
———————————————————————————-
#!/bin/sh
if [ $# -lt 3 ]
then
echo -n “using : mencoder_encoder.sh <filename> <x_geometry> <y_geometry> ( movie 400 300 )
“;
exit;
fi
mencoder -noodml $1.avi -o $1.flv -sub $1.smi -of lavf -oac mp3lame -lameopts abr:br=128 -ovc lavc -lavcopts vcodec=flv:vbitrate=512:mbd=2:mv0:trell:v4mv:cbp:last_pred=3 -srate 44100 -lavfopts i_certify_that_my_video_stream_does_not_use_b_frames -vf-add scale=${2}:${3}
ffmpeg -y -i $1.avi -vframes 1 -ss 00:00:02 -an -vcodec png -f rawvideo -s ${2}x${3} $1.png
flvtool2 -U $1.flv
echo -n “——————————————————–
$1.avi completed $1.flv to encoding..!!
——————————————————–
“;
———————————————————————————
디렉토리내 flv 파일을 UCCUP Player에서 인식할 수 있는 HTML 코드로 변환하는 스크립트
# vi /usr/bin/convert_flvhtml.sh
——————————————————————————–
#!/bin/sh
rm -f source.html
ls -1 *.flv | sed -e ‘s/.flv//g’ > filelist
A=`cat filelist`
for B in `echo $A`
do
echo -n ”
<embed src=”
http://syszone.co.kr/uccup/UCCUp.swf?file=http://syszone.co.kr/uccup/file.php?f=${B}.flv&previewImage=http://syszone.co.kr/uccup/file.php?f=${B}.png&bufferTime=3&bgColor=-1
width=400 height=300 scale=noscale bgcolor=#ffffff type=application/x-shockwave-flash allowFullScreen=true
allowScriptAccess=always allowNetworking=all pluginspage=http://www.macromedia.com/go/getflashplayer>
</embed>
<p>
” >> source.html
done
———————————————————————————

4.2 RED5 를 이용한 스트리밍 서비스 환경 구축하기
– Red5 설치하기
ant download :  http://ant.apache.org/bindownload.cgi
red5 download : http://osflash.org/red5
jdk download : http://java.sun.com

각 사이트에서 최신 패키지를 다운받는다.
apache-ant-1.7.1-bin.tar.gz
red5-0.7.0.tar.gz
jdk-6u11-linux-x64-rpm.bin
– JDK 설치하기
# chmod 755 jdk-6u11-linux-x64-rpm.bin
# ./jdk-6u11-linux-x64-rpm.bin
——————————————————————————–
.
.
Do you agree to the above license terms? [yes or no]
yes
Unpacking…
Checksumming…
Extracting…
UnZipSFX 5.50 of 17 February 2002, by Info-ZIP (Zip-Bugs@lists.wku.edu).
inflating: jdk-6u11-linux-amd64.rpm
inflating: sun-javadb-common-10.4.1-3.1.i386.rpm
inflating: sun-javadb-core-10.4.1-3.1.i386.rpm
inflating: sun-javadb-client-10.4.1-3.1.i386.rpm
inflating: sun-javadb-demo-10.4.1-3.1.i386.rpm
inflating: sun-javadb-docs-10.4.1-3.1.i386.rpm
inflating: sun-javadb-javadoc-10.4.1-3.1.i386.rpm
준비 중…                  ########################################### [100%]
.
.
Press Enter to continue…..
Done.
/usr/java 디렉토리 밑에 설치 완료 .
– Ant 설치하기
# tar xzvf apache-ant-1.7.1-bin.tar.gz
# mv apache-ant-1.7.1 /usr/local/ant
– Red5 설치하기
# mkdir /usr/local/red5
# tar xzvf red5-0.7.0.tar.gz -C /usr/local/red5
– 환경설정하기
# vi /etc/profile.d/ant_java.sh
—————————————————————————–
#!/bin/sh
export JAVA_HOME=/usr/java/default
export JAVA_VERSION=1.6
export ANT_HOME=/usr/local/ant
export PATH=${ANT_HOME}/bin:${JAVA_HOME}/bin:$PATH
—————————————————————————-
# source /etc/profile.d/ant_java.sh
# java -version
java version “1.6.0_11”
Java(TM) SE Runtime Environment (build 1.6.0_11-b03)
Java HotSpot(TM) 64-Bit Server VM (build 11.0-b16, mixed mode)
– RED5 컴파일 및 데몬 시작하기

http://osflash.org/red5 에서 final 바이너리 패키지를 받은 경우 별도의 컴파일
없이 바로 실행이 가능하다.
# cd /usr/local/red5
# sh red5.sh
svn를 통해 코드를 받은 경우 아래와 같이 컴파일을 해줘야 한다.
# cd /usr/local
# svn co
http://red5.googlecode.com/svn/java/server/trunk red5src
# cd red5
방법1 :
# cd /usr/local/red5src
# ant server &
# /usr/local/ant/bin/ant
# cp -a /usr/local/red5src/dist /usr/local/red5
# cd /usr/local/red5
# ./red5.sh &
방법2 :
# cd /usr/local/red5src
# make
# make install
# cd /usr/lib/red5
# ./red5.sh &
방법 3 :
# cd /usr/local/red5src
# ant prepare
# ant build
Target “build” does not exist in the project “RED5”. 라는 에러가 발생했을 경우
# ant
or
# ant -f build.xml
# cp -a dist /usr/local/red5
# cd /usr/local/red5
# sh red5.sh &
;; 3번 권장함

최신버전으로 컴파일 시 간혹 아래와 같은 에러가 발생하는 경우가 있다.
————————————————————————
.
[ivy:resolve]           :: spring#spring-support;2.0.8: not found
[ivy:resolve]           :: javax#jsp-api;2.1: not found
[ivy:resolve]           :: red5#xercesImpl;2.9.0: not found
[ivy:resolve]           :: red5#groovy;1.0: not found
[ivy:resolve]           :: commons#commons-lang;2.3: not found
[ivy:resolve]           :: tomcat#jasper;6.0.14: not found
[ivy:resolve]           ::::::::::::::::::::::::::::::::::::::::::::::
[ivy:resolve]
[ivy:resolve] :: USE VERBOSE OR DEBUG MESSAGE LEVEL FOR MORE DETAILS
BUILD FAILED
/usr/local/red5-0.7.0/build.xml:205: The following error occurred while executing this line:
/usr/local/red5-0.7.0/build.xml:221: The following error occurred while executing this line:
/usr/local/red5-0.7.0/build.xml:165: impossible to resolve dependencies:
resolve failed – see output for details
————————————————————————

위 문제는 ivy 라는 패키지 관리 도구에서 red5 컴파일 시 필요한 패키지를 사전에 정의된
패키지 저장소에서 자동으로 다운로드 받게 되는데, 필요한 패키지를 찾을 수 없을때 발생한다.
ivy.xml 와 ivysettings.xml 파일에 다운로드 경로 정보가 있는데, 이것이 변동된 경우 발생하니
ivysettings.xml 에서
http://red5.googlecode.com/svn/trunk/repository/ 부분을
http://red5.googlecode.com/svn/repository 로 수정하거나 최신 해당 파일을 다운로드 받으면
된다.

– Init script 만들기
# vi /etc/rc.d/init.d/red5
————————————————————————–
#!/bin/sh
#
# Startup script for Red5 flash streaming server
#
# chkconfig: 345 81 81
# description: RED5 by java
#
# processname: java (unfortunately)
# pidfile: /var/run/red5.pid
# config: /etc/red5.conf
# Source function library.
. /etc/rc.d/init.d/functions
PID_FILE=/var/run/red5.pid
PID=`ps ax |grep java|grep red5|awk ‘{print $1;}’`
RETVAL=0
start() {
echo -n $”Starting $DESCR: ”
# daemon java $OPTIONS > /dev/null 2>&1 &
export ANT_HOME=/usr/local/ant
export JAVA_HOME=/usr/java/default
export PATH=$PATH:$JAVA_HOME/bin:$ANT_HOME/bin
export CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
exec $JAVA_HOME/bin/java -Djava.security.manager -Djava.security.policy=/usr/local/red5/conf/red5.policy -cp /usr/local/red5/red5.jar:conf:/usr/local/red5/conf org.red5.server.Standalone > /dev/null 2>&1 & RETVAL=$?
[ $RETVAL = 0 ] && touch /var/lock/subsys/red5 && echo $!>$PID_FILE && echo_success
echo
return $RETVAL
}
stop() {
echo -n $”Stopping $DESCR: ”
#killproc $PID_FILE
[[ $PID != “” ]] && success && kill $PID || failure
RETVAL=$?
echo
[ $RETVAL = 0 ] && rm -f /var/lock/subsys/red5 $PID_FILE
}
# See how we were called.
case “$1″ in
start)
start
;;
stop)
stop
;;
restart)
stop
sleep 3
start
;;
*)
echo $”Usage: $DESCR {start|stop|restart}”
exit 1
esac
exit $RETVAL
—————————————————————————-
# chmod 755 /etc/rc.d/init.d/red5
# chkconfig –add /etc/rc.d/init.d/red5
# /etc/rc.d/init.d/red5 start

– red5 spec file
—————————————————————————-
Summary: Red5 Server
Name: red5
Version: 0.7.0
Release: 1
Source0: %{name}-%{version}.tar.gz
License: LGPL
Group: Applications/Networking
BuildRoot: %{_builddir}/%{name}-root
%description
The Red5 open source Flash server allows you to record and stream video to the Flash Player.
%prep
%setup -q
%build
ant dist-installer
%install
cp dist $RPM_BUILD_ROOT
%clean
rm -rf $RPM_BUILD_ROOT
%files
%defattr(-,root,root)
/usr/local/bin/red5.init
%doc doc/changelog.txt
——————————————————————————
– Red5를 이용한 flv 동영상 스트리밍 Player 환경 구성하기
flash_media_player.zip 파일을 다운로드 받는다.
http://www.jeroenwijering.com/upload/flash_media_player.zip

# cp mediaplayer.html index.html
# vi index.html
——————————————————————————
<html>
<head>
<script type=”text/javascript” src=”swfobject.js”></script>
</head>
<body>

<p id=”player2″><a href=”http://www.macromedia.com/go/getflashplayer”>Get the Flash Player</a> to see this player.</p>
<script type=”text/javascript”>
var s2 = new SWFObject(“mediaplayer.swf”,”playlist”,”640″,”640″,”9″);
s2.addParam(“allowfullscreen”,”true”);
s2.addVariable(“file”,”playlist.xml”);
s2.addVariable(“displayheight”,”480″);
s2.addVariable(“backcolor”,”0x000000″);
s2.addVariable(“frontcolor”,”0xCCCCCC”);
s2.addVariable(“lightcolor”,”0x996600″);
s2.write(“player2”);
</script>

</body>
</html>
———————————————————————————-
# vi playlist.xml
———————————————————————————-
<playlist version=”1″ xmlns=”
http://xspf.org/ns/0/“>
<trackList>
<track>
<title>Resident.Evil.Degeneration.2008</title>
<creator>alang</creator>
<location>rtmp://syszone.co.kr/oflaDemo/</location>
<identifier>residentevil.flv</identifier>
<meta rel=”type”>rtmp</meta>
</track>
</trackList>
.
.
</playlist>
———————————————————————————-

위의 <location>rtmp://syszone.co.kr/oflaDemo/</location> 에 해당 red5 streams 디렉토리
경로를 지정한다.
기본 경로는 [RED5_PATH]/webapps/oflaDemo/streams 디렉토리 밑에 flv 파일을 넣어두면된다.
– RED5와 OpenLaszlo를 이용한 스트리밍 환경 구축하기

http://www.openlaszlo.org 에서 최신 패키지를 다운받는다.
최신 개발 패키지  :
http://download.openlaszlo.org/nightly/trunk
# tar xzvf openlaszlo-4.2.0-unix.tar.gz
# mv lps-4.2.0 /usr/local/lps
# cd /usr/local/lps/Server/tomcat-5.0.24/bin
# ./startup.sh
———————————————————————————-
Using CATALINA_BASE:   /usr/local/lps/Server/tomcat-5.0.24
Using CATALINA_HOME:   /usr/local/lps/Server/tomcat-5.0.24
Using CATALINA_TMPDIR: /usr/local/lps/Server/tomcat-5.0.24/temp
Using JAVA_HOME:       /usr/java/default
———————————————————————————-

http://domain:8080/lps-4.2.0/demos/

# cd /usr/local/lps/Server/lps-4.2.0/demos/videolibrary
# vi videolibrary.lzx
———————————————————————————-
<include href=”av/videoutils.lzx”/> -> 삭제
.
.
<dataset name=”ds_library”
src=”http:videolibrary.jsp?method=getLibrary”
request=”true”
/>
이 부분을 ..
<dataset name=”ds_library”
src=”http://192.168.123.2:8080/lps-4.2.0/demos/videolibrary/videolibrary.jsp?method=getLibrary
request=”true”
/>
으로 ..

    <rtmpconnection id=”rtc”
autoconnect=”true”
debug=”true”
src=”rtmp:localhost/test/instance1″
/>

이 부분을 ..
<rtmpconnection id=”rtc”
autoconnect=”true”
debug=”true”
src=”rtmp://192.168.123.90/oflaDemo”
/>
으로 변경
———————————————————————————-
# vi videolibrary.jsp
———————————————————————————
public String libraryDirectory =
“/home/fms/applications/test/streams/instance1/”; –> 이부분을 ..
“/usr/local/red5/webapps/oflaDemo/streams/” 으로 ..
public String libraryUrl =
“rtmp://localhost/test/instance1/”; –> 이부분을
“rtmp://domain/oflaDemo/”; 으로 ..
———————————————————————————
아래 주소로 접속하면 확인이 가능하다.

http://192.168.123.2:8080/lps-4.2.0/demos/videolibrary/videolibrary.lzx
;; flv 파일명이 한글이면 안된다.
;; flv 파일 리스트와 썸네일이 보이지 않는다.
– thumbnail 관련 임시 조치
# cd /usr/local/lps/Server/lps-4.2.x/demos/videolibrary
# vi videolibrarythumbnail.lzx
——————————————————————————–
.
<videothumbnail name=”vt”
.
thumbnailtime=”${classroot.thumbnailtime}” resource=”resources/thumbnail.jpg”
/>
——————————————————————————–
resources=”원하는 thumbnail 파일 경로” 적어 준다.
….ㅠ.ㅠ
– lps URL 변경
# cd /usr/local/lps/Server/tomcat-5.0.24/conf/LPS/localhost
# vi lps.xml
——————————————————————————–
<Context docBase=”../../lps-4.2.x” path=”/lps-4.2.x”>
위의 path=”” 에 url에 표시될 alias명을 적는다.

http://domain:8080/<alias_name>
– SOLO 기능 이용하기
solo 는 laszlo에서 개발된 내용을 HTML과 swf 형태로 변경해 주는 관리 기능이다.
실제 laszlo로 미디어 관련 어플리케이션을 개발한 후 최종적으로는 solo를 이용하여
웹 컨텐츠 형태로 변형 시켜 사용한다.
solo 버턴을 클릭하면 해당 컨텐츠가 zip 파일로 압축된다.
압축 파일 위치는 /usr/local/lps/Server/lps-4.2.x/lps/admin 이다.
웹서버의 적당한 디렉토리 및에 해당 파일을 풀고 사용하면 된다.


4.3 WebCam 설치하기
– webcam driver 다운로드
$ wget
http://mxhaard.free.fr/spca50x/Download/gspcav1-20071224.tar.gz
$ wget http://forums.quickcamteam.net/attachment.php?aid=86 -O patch.tar.gz
– driver 패치 및 설치
$ tar -xvf gspcav1-20071224.tar.gz
$ tar -xvf patch.tar.gz
$ cd gspcav1-20071224
$ patch -p1 < ../quickcamE2500.diff
$ ./gspca_build
>> gspca.ko파일이 생성된다.
$ lsmod | grep gspca            // videodev가 보일것이다.

$ rmmod gspca
$ modprobe -v gspca
>> insmod /lib/modules/2.6.18-92.el5/kernel/driver/usb/media/gspca.ko
대략 저러한것들이 보인다.
없을 경우..

$ rmmod gspca
$ mv gspca.ko /lib/modules/2.6.18-92.el5//kernel/driver/media/video/
$ modprobe gspca
위와 같이 해당위치에 파일을 옮겨주다.
# cd /lib/modules
# depmod -a 2.6.18-92.el5
# mknod /dev/video0 c 81 0
# ln -sf /dev/video0 /dev/video
– webcam viewer 설치 (xawtv)
# yum install xawtv

Writer profile
author image
-아랑 –

One Response to RED5 & FFMPEG & FFserver 스트리밍 서버 구축하기

  1. I am continuously looking online for ideas that can facilitate me. Thank you!