[UPADTE] - refact code
This commit is contained in:
parent
b779db2d6d
commit
a042dea4fe
4
.env
4
.env
@ -1,6 +1,8 @@
|
||||
#####################################
|
||||
# Repository generator
|
||||
|
||||
# Version of image
|
||||
RepoVers=1
|
||||
# Centos Version
|
||||
CentOsVersion=7.9.2009
|
||||
# Sync repo script
|
||||
@ -14,6 +16,8 @@ RunArg=del
|
||||
#####################################
|
||||
# Esl compilator
|
||||
|
||||
# Version of image
|
||||
GenVers=1
|
||||
# Programme local directory
|
||||
ProgrammeDir=/data/GIT/ESL_PRODUIT
|
||||
# Repositories Directory
|
||||
|
||||
Binary file not shown.
@ -2,7 +2,7 @@ FROM centos:centos7
|
||||
LABEL maintainer='Guillaume Astier Ruiz'
|
||||
|
||||
ENV os='centos'
|
||||
osversion='7'
|
||||
ENV osversion='7'
|
||||
|
||||
RUN yum install -y perl perl-Business-ISBN perl-Business-ISBN-Data perl-Carp perl-Compress-Raw-Bzip2 perl-Compress-Raw-Zlib perl-Data-Dumper perl-Data-OptList perl-Digest perl-Digest-MD5 perl-Encode perl-Encode-Locale perl-Error perl-Exporter perl-ExtUtils-Install perl-ExtUtils-MakeMaker perl-ExtUtils-Manifest perl-ExtUtils-ParseXS perl-File-Listing perl-File-Path perl-File-Temp perl-Filter perl-Font-AFM perl-Getopt-Long perl-HTML-Format perl-HTML-Parser perl-HTML-Tagset perl-HTML-Tree perl-HTTP-Cookies perl-HTTP-Daemon perl-HTTP-Date perl-HTTP-Message perl-HTTP-Negotiate perl-HTTP-Tiny perl-IO-Compress perl-IO-HTML perl-IO-Socket-IP perl-IO-Socket-SSL perl-IO-stringy perl-LWP-MediaTypes perl-Module-Implementation perl-Module-Runtime perl-Mozilla-CA perl-Net-HTTP perl-Net-LibIDN perl-Net-SSLeay perl-Package-Generator perl-PadWalker perl-Params-Util perl-Params-Validate perl-PathTools perl-Pod-Escapes perl-Pod-Perldoc perl-Pod-Simple perl-Pod-Usage perl-Scalar-List-Utils perl-Socket perl-Storable perl-Sub-Exporter perl-Sub-Install perl-TermReadKey perl-Test-Harness perl-Text-ParseWords perl-Thread-Queue perl-Time-HiRes perl-Time-Local perl-TimeDate perl-Tk perl-Try-Tiny perl-URI perl-WWW-RobotRules perl-XML-Catalog perl-XML-DOM perl-XML-Dumper perl-XML-Filter-BufferText perl-XML-Grove perl-XML-Handler-YAWriter perl-XML-LibXML perl-XML-LibXSLT perl-XML-NamespaceSupport perl-XML-Parser perl-XML-RegExp perl-XML-SAX perl-XML-SAX-Base perl-XML-SAX-Writer perl-XML-Simple perl-XML-TokeParser perl-XML-TreeBuilder perl-XML-Twig perl-XML-Writer perl-XML-XPath perl-XML-XPathEngine perl-constant perl-devel perl-libs perl-libwww-perl perl-libxml-perl perl-macros perl-parent perl-podlators perl-srpm-macros perl-threads perl-threads-shared
|
||||
RUN yum install -y basesystem binutils bzip2 cpp createrepo dejavu-fonts-common dejavu-sans-fonts deltarpm dwz elfutils elfutils-devel elfutils-libelf-devel fontconfig fontpackages-filesystem gcc gdb gdbm-devel genisoimage glibc-devel glibc-headers gpm-libs groff-base keyutils-libs-devel libX11 libX11-common libXau libXft libXrender libcom_err-devel libdb-devel libjpeg-turbo libmpc libselinux-devel libsepol-devel libusal libverto-devel libxcb libxml2-python lm_sensors-devel lm_sensors-libs mailcap mpfr ncurses-base net-tools openssl-devel pcre-devel popt-devel pyparsing python-deltarpm python-gobject-base python-srpm-macros redhat-rpm-config rpm-build rpm-devel rsync strace tcp_wrappers-devel tree unzip vim-common vim-enhanced vim-filesystem xz-devel zip zlib-devel nginx openssh-clients
|
||||
@ -12,5 +12,5 @@ RUN yum install -y net-snmp
|
||||
|
||||
COPY ./bin/run.sh /bin/run.sh
|
||||
RUN chmod 777 /bin/run.sh
|
||||
CMD ["/bin/run.sh ${Run}"]
|
||||
CMD [/bin/run.sh ${Run}]
|
||||
|
||||
@ -2,7 +2,7 @@ FROM centos:${CentOsVersion}
|
||||
LABEL maintainer='Guillaume Astier Ruiz'
|
||||
|
||||
ENV os='centos'
|
||||
osversion='7'
|
||||
ENV osversion='7'
|
||||
|
||||
|
||||
RUN yum install yum-utils createrepo vim wget -y
|
||||
@ -12,4 +12,4 @@ RUN chmod 755 /bin/sync.sh
|
||||
COPY ./bin/empty.sh /bin/empty.sh
|
||||
RUN chmod 755 /bin/empty.sh
|
||||
|
||||
CMD ["${Run} ${RunArg}"]
|
||||
CMD [${Run} ${RunArg}]
|
||||
|
||||
48
README.md
48
README.md
@ -4,38 +4,46 @@
|
||||
|
||||
```
|
||||
.
|
||||
.
|
||||
├── bin
|
||||
│ ├── empty.sh
|
||||
│ ├── run.sh
|
||||
│ └── sync.sh
|
||||
├── data
|
||||
│ ├── log
|
||||
│ └── repo
|
||||
├── docker-compose.yml
|
||||
└── Dockerfile
|
||||
└── README.md
|
||||
├── define.conf -> .env
|
||||
├── docker-compose.yml.esl
|
||||
├── docker-compose.yml.repo
|
||||
├── Dockerfile
|
||||
├── DockerFile
|
||||
│ ├── Dockerfile.esl
|
||||
│ └── Dockerfile.repo
|
||||
├── generate_env.sh
|
||||
├── README.md
|
||||
└── template
|
||||
|
||||
4 directories, 4 files
|
||||
3 directories, 10 files
|
||||
|
||||
```
|
||||
|
||||
## Use
|
||||
|
||||
### 1./ Build Docker image : c7repo
|
||||
### 1./ Build Docker image
|
||||
|
||||
```
|
||||
guillaume@virgile:~/centos79repo/$ docker build . -t c7repo
|
||||
Sending build context to Docker daemon 7.68kB
|
||||
Step 1/10 : FROM centos:7.9.2009
|
||||
---> eeb6ee3f44bd
|
||||
[...]
|
||||
Step 10/10 : CMD ["/bin/sync.sh"]
|
||||
---> Running in 8ea78a88d33d
|
||||
Removing intermediate container 8ea78a88d33d
|
||||
---> be87c9d3dc38
|
||||
Successfully built be87c9d3dc38
|
||||
Successfully tagged c7repo:latest
|
||||
guillaume@virgile:~/centos79repo/$ ./generate_env.sh image
|
||||
Delete Dockerfile ... : OK
|
||||
generate Dockerfile Esl compilator ... : OK
|
||||
Generate compilator Docker image ... : OK
|
||||
Delete Dockerfile ... : OK
|
||||
generate Dockerfile CentOS REPO ... : OK
|
||||
Generate Repo Docker image ... : OK
|
||||
|
||||
------ Log Compil -----------
|
||||
/tmp/DockerCompilatorGenerate.log
|
||||
/tmp/DockerRepoGenerate.log
|
||||
-----------------------------
|
||||
```
|
||||
|
||||
### 2./ Start sync with docker compose
|
||||
### 2./ Start sync repositories t
|
||||
|
||||
```
|
||||
guillaume@virgile:~/centos79repo$ docker-compose up -d
|
||||
|
||||
@ -3,7 +3,7 @@ version: '2'
|
||||
|
||||
services:
|
||||
compil:
|
||||
image: esl-compilator
|
||||
image: esl-compilator:${GenVers}
|
||||
volumes:
|
||||
- ${ProgrammeDir}:/data
|
||||
- ${RepoDir}:/data/distributions
|
||||
|
||||
@ -3,7 +3,7 @@ version: '2'
|
||||
|
||||
services:
|
||||
c7repo:
|
||||
image: c7repo
|
||||
image: c7repo:${RepoVers}
|
||||
volumes:
|
||||
- ./data:/data
|
||||
|
||||
|
||||
@ -28,6 +28,8 @@ help () {
|
||||
$0 [image/repo/esl/all]
|
||||
|
||||
* image : Generate docker images
|
||||
* image-gen : Generate docker image for esl compilator
|
||||
* image-repo : Generate docker image for repository sync
|
||||
* repo : start docker compose and generate repositories
|
||||
* esl : start docker compose and generarte esl
|
||||
* all : Do everything
|
||||
@ -46,116 +48,90 @@ TestEnv docker
|
||||
TestEnv tput
|
||||
|
||||
|
||||
LogDockerCompilatorGenerate=/tmp/DockerCompilatorGenerate.log
|
||||
LogDockerRepoGenerate=/tmp/DockerRepoGenerate.log
|
||||
LogDockerCompilatorRun=/tmp/DockerCompilatorRun.log
|
||||
LogDockerRepoRun=/tmp/DockerRepoRun.log
|
||||
|
||||
|
||||
cd ${Wai}
|
||||
|
||||
DeleteFile() {
|
||||
|
||||
DockerGen() {
|
||||
echo -n "Delete Dockerfile ... : "
|
||||
[[ -f ${Wai}/Dockerfile ]] && rm Dockerfile || true
|
||||
Res $?
|
||||
|
||||
}
|
||||
|
||||
echo -n "generate Dockerfile Esl compilator ... : "
|
||||
DeleteImg () {
|
||||
DeleteFile
|
||||
echo -n "Delte old images $1 ... : "
|
||||
for var in $(docker image ls| grep "esl-$1" | awk '{print $3}'); do yes | docker image rm $var --force; done &> /dev/null
|
||||
Res $?
|
||||
}
|
||||
|
||||
DockerGen() {
|
||||
DeleteImg $1
|
||||
echo -n "generate Dockerfile $1 ... : "
|
||||
source define.conf
|
||||
while read line
|
||||
do
|
||||
if [[ ! -z $(echo "$line" | grep '\$') ]]
|
||||
if [[ ! -z $(echo $line | grep '\$') ]]
|
||||
then
|
||||
eval echo "${line}"
|
||||
eval echo ${line} | sed "s#\[#\[\'#g" | sed "s#\]#\'\]#g"
|
||||
else
|
||||
echo $line
|
||||
fi
|
||||
done < DockerFile/Dockerfile.esl > Dockerfile
|
||||
done < DockerFile/Dockerfile.$1 > Dockerfile
|
||||
Res $?
|
||||
|
||||
echo -n "Delete Dockerfile ... : "
|
||||
[[ -f ${Wai}/Dockerfile ]] && rm Dockerfile || true
|
||||
Res $?
|
||||
|
||||
|
||||
echo -n "Generate compilator Docker image ... : "
|
||||
docker build . -t esl-compilator 2>&1 | tee $LogDockerCompilatorGenerate &> /dev/null
|
||||
Res $?
|
||||
|
||||
echo -n "generate Dockerfile CentOS REPO ... : "
|
||||
while read line
|
||||
do
|
||||
if [[ ! -z $(echo "$line" | grep '\$') ]]
|
||||
then
|
||||
eval echo "${line}"
|
||||
else
|
||||
echo $line
|
||||
fi
|
||||
done < DockerFile/Dockerfile.repo > Dockerfile
|
||||
Res $?
|
||||
|
||||
|
||||
|
||||
echo -n "Generate Repo Docker image ... : "
|
||||
docker build . -t c7repo 2>&1 | tee $LogDockerRepoGenerate &> /dev/null
|
||||
echo -n "Generate $1 Docker image ... : "
|
||||
docker build --no-cache . -t esl-$1:${GenVers} 2>&1 | tee /tmp/BuildDocker-${1}.log &> /dev/null
|
||||
Res $?
|
||||
|
||||
echo "
|
||||
------ Log Compil -----------
|
||||
$LogDockerCompilatorGenerate
|
||||
$LogDockerRepoGenerate
|
||||
/tmp/BuildDocker-${1}.log
|
||||
-----------------------------
|
||||
"
|
||||
|
||||
}
|
||||
|
||||
|
||||
DockerComposeRunEsl () {
|
||||
[[ $1 == "Print" ]] && Print="" || Print="-d"
|
||||
echo -n "Starting ESL COMPILATOR ... : "
|
||||
docker-compose -f docker-compose.yml.esl up ${Print} --remove-orphans 2>&1 ${LogDockerCompilatorRun} &> /dev/null
|
||||
DockerComposeRun () {
|
||||
[[ $2 == "Print" ]] && Print="" || Print="-d"
|
||||
echo -n "Starting DOCKER $1 ... : "
|
||||
docker-compose -f docker-compose.yml.$1 up ${Print} --remove-orphans 2>&1 | tee /tmp/RunDocker-${1}.log &> /dev/null
|
||||
Res $?
|
||||
echo "
|
||||
--------- Log Esl -----------
|
||||
$LogDockerCompilatorRun
|
||||
/tmp/RunDocker-${1}.log
|
||||
-----------------------------
|
||||
"
|
||||
}
|
||||
|
||||
DockerComposeRunRepo () {
|
||||
echo -n "Starting Repo Sync ... : "
|
||||
echo "docker-compose -f docker-compose.yml.repo up --remove-orphans ${Print} "
|
||||
exit
|
||||
docker-compose -f docker-compose.yml.repo up --remove-orphans ${Print} 2>&1 ${LogDockerRepoRun} &> /dev/null
|
||||
Res $?
|
||||
echo "
|
||||
-------- Log Repo -----------
|
||||
$LogDockerRepoRun
|
||||
-----------------------------
|
||||
"
|
||||
|
||||
}
|
||||
|
||||
|
||||
Exec=$1
|
||||
|
||||
|
||||
GenAll () {
|
||||
DockerGen gen
|
||||
DockerGen repo
|
||||
}
|
||||
|
||||
[[ -z "${Exec}" ]] && help
|
||||
[[ "${Exec}" == "image" ]] && DockerGen
|
||||
[[ "${Exec}" == "image" ]] && GenAll
|
||||
[[ "${Exec}" == "image-gen" ]] && DockerGen gen
|
||||
[[ "${Exec}" == "image-repo" ]] && DockerGen repo
|
||||
|
||||
|
||||
|
||||
[[ "${Exec}" == "repo" ]] && DockerComposeRunRepo
|
||||
[[ "${Exec}" == "esl" ]] && DockerComposeRunEsl
|
||||
|
||||
[[ "${Exec}" == "repo" ]] && DockerComposeRun repo
|
||||
[[ "${Exec}" == "gen" ]] && DockerComposeRun gen
|
||||
|
||||
|
||||
if [[ "${Exec}" == "all" ]]
|
||||
then
|
||||
DockerGen
|
||||
DockerComposeRunRepo Print
|
||||
DockerComposeRunEsl Print
|
||||
DockerComposeRun repo Print
|
||||
DockerComposeRun gen Print
|
||||
fi
|
||||
|
||||
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user