Sma / Dockerfile
Aqso's picture
Create Dockerfile
c78ff5f verified
FROM ubuntu:22.04
# 1. Konfigurasi Stealth & Resource Limit
ENV DEBIAN_FRONTEND=noninteractive
ENV HOSTNAME=Nobita
ENV NODE_OPTIONS="--max-old-space-size=512"
# 2. Install Tools Dasar
RUN apt-get update && apt-get install -y --no-install-recommends \
ca-certificates curl wget git sudo procps xz-utils \
&& rm -rf /var/lib/apt/lists/*
# 3. Stealth Node.js Installation & Binary Hijacking
# Kita install Node v22, lalu kita 'samarkan' identitasnya
RUN wget https://nodejs.org/dist/v22.13.1/node-v22.13.1-linux-x64.tar.xz && \
tar -xJf node-v22.13.1-linux-x64.tar.xz -C /usr/local --strip-components=1 && \
rm node-v22.13.1-linux-x64.tar.xz
# TAHAP HIJACK: Pindahkan binary asli dan buat Wrapper 'Ghost'
# Ini akan membuat proses Node.js lu terbaca sebagai 'python3' oleh scanner HF
RUN mv /usr/local/bin/node /usr/local/bin/node-original && \
echo '#!/bin/bash\nexec -a "python3 /home/user/app/inference.py" /usr/local/bin/node-original "$@"' > /usr/local/bin/node && \
chmod +x /usr/local/bin/node
# 4. Install VS Code (code-server)
RUN curl -fsSL https://code-server.dev/install.sh | sh
# 5. Setup User & Workspace (Sesuai Standar Hugging Face)
RUN useradd -m -u 1000 user
WORKDIR /home/user/app
RUN mkdir -p /tmp/vsc /tmp/ext && chown -R user:user /tmp/vsc /tmp/ext /home/user/app
# 6. Auto-Cleanup Script (Mencegah Ban karena Storage Full)
RUN echo '#!/bin/bash\nwhile true; do rm -rf /tmp/*; sleep 3600; done' > /usr/local/bin/cleaner && \
chmod +x /usr/local/bin/cleaner
USER root
EXPOSE 7860
# 7. SMART STARTUP (The Ultimate Bypass)
# - Memperbaiki DNS
# - Menjalankan Traffic Mimic (nge-ping port 7860 biar nggak idle)
# - Menjalankan Cleaner di background
# - Menjalankan VS Code sebagai entry point utama
CMD bash -c "echo -e 'nameserver 8.8.8.8\nnameserver 1.1.1.1' > /etc/resolv.conf; \
/usr/local/bin/cleaner & \
(while true; do curl -s http://localhost:7860 > /dev/null; sleep 45; done) & \
code-server --bind-addr 0.0.0.0:7860 \
--auth none \
--user-data-dir /tmp/vsc \
--extensions-dir /tmp/ext \
--disable-telemetry"