[[oktatas:linux:ftp_szerver|< Ftp szerver]] ====== Pure-ftpd ====== * **Szerző:** Sallai András * Copyright (c) Sallai András, 2011, 2013, 2018 * Licenc: GNU Free Documentation License 1.3 * Web: http://szit.hu ===== Az FTP szerverről ===== Az Interneten az első funkció amit használtak az a fájlok átvitele. Az FTP a File Transfer Protocol angol szavakból alkotott betűszó. Úgy fordíthatjuk, hogy Fájl Átviteli Protokoll. Alapértelmezetten a 21 porton fogad kapcsolatokat és a 20-as porton szolgálja ki az adatokat. Passzív módban azonban a 21-es portot használja, vezérlésre, az adatátvitelre pedig 1023 felett egy portot. ===== Telepítés ===== apt-get install pure-ftpd Telepítés után minden linuxos felhasználó hozzáférhet saját könyvtárához FTP kapcsolaton keresztül. A legújabb verzió beszerezhető itt: * http://pure-ftpd.org ===== Tesztelés ===== # ps ax # ss -lt # apt install ftp # adduser mari $ ftp localhost Connected to localhost. 220---------- Welcome to Pure-FTPd [privsep] [TLS] ---------- 220-You are user number 1 of 50 allowed. 220-Local time is now 19:22. Server port: 21. 220-This is a private system - No anonymous login 220 You will be disconnected after 15 minutes of inactivity. Name (localhost:janos): mari 331 User mari OK. Password required Password: 230 OK. Current directory is /home/mari Remote system type is /home/mari Using binary mode to transfer files. ftp> ===== Virtuális felhasználók ===== ==== A pure-ftpd beállítása ==== Először rá kell vennünk a pure-ftpd programot, hogy kezelje saját virtuális felhasználóit: ln -s /etc/pure-ftpd/conf/PureDB /etc/pure-ftpd/auth/60PureDB Létre kell hoznunk a rendszerben egy ftpgroup csoportot és egy ftpuser felhasználót. A pure-ftpd program ezen felhasználó és csoport jogaival fog hozzáférni a fájlrendszerhez: groupadd -g 5000 ftpgroup useradd -u 5000 -d /dev/null -c "pureftpd user" -g ftpgroup -s /bin/false ftpuser Ha készen van, végig kell gondolnunk a virtuális felhasználók könyvtárai hol lesznek. Ez lehet például a /home/virtual-ftp könyvtár. Hozzuk létre: mkdir /home/virtual-ftp/ Ha egy Joe nevű felhasználónak akarunk hozzáférést adni akkor virtual-ftp könyvtárban készítsunk számára alkönyvtárat: mkdir /home/virtual-ftp/joe chown ftpuser.ftpgroup /home/virtual-ftp/joe A pure-ftpd szerver újraindítása előtt vegyünk fel minimum egy felhasználót, mert másként panaszkodni fog a /etc/pure-ftpd/pureftpd.pdf fájl hiányára. ==== Felhasználókezelés ==== === Felhasználó felvétele === Vegyük fel a joe virtuális felhasználót: pure-pw useradd joe -d /home/virtual-ftp/joe -u ftpuser -g ftpgroup -m /etc/init.d/pure-ftpd restart Ha az adott könyvtárban az apache webszervernek írni kell, akkor tegyük az ftpuser felhasználót a www-data csoport tagjává. === Felhasználó törlése === pure-pw userdel jozsi -m === Jelszó megváltoztatása === pure-pw passwd jozsi -m === Felhasználó jellemzőinek megváltoztatása === pure-pw usermod jozsi -d /home/virtual-ftp/ujkonyvtar -m A példában a jozsi felhazsnálónak egy másik könyvtárat adunk meg. === Adatbázis aktualizálása === pure-pw mkdb ===== Virtuális felhasználók MySQL-ben ===== apt-get install pure-ftpd-mysql mysql-server-5.0 mysql -u root -p GRANT ALL PRIVILEGES ON ftpd.* TO 'ftpd'@'localhost' IDENTIFIED BY 'titok'; FLUSH PRIVILEGES; CREATE TABLE users ( User VARCHAR(16) BINARY NOT NULL, Password VARCHAR(64) BINARY NOT NULL, Uid INT(11) NOT NULL default '-1', Gid INT(11) NOT NULL default '-1', Dir VARCHAR(128) BINARY NOT NULL, PRIMARY KEY (User) ); mcedit /etc/pure-ftpd/conf/db/mysql.conf #MYSQLServer localhost #MYSQLPort 3306 MYSQLSocket /var/run/mysqld/mysqld.sock MYSQLUser ftpd MYSQLPassword titok MYSQLDatabase pureftpd MYSQLCrypt cleartext MYSQLGetPW SELECT Password FROM users WHERE User="\L" MYSQLGetUID SELECT Uid FROM users WHERE User="\L" MYSQLGetGID SELECT Gid FROM users WHERE User="\L" MYSQLGetDir SELECT Dir FROM users WHERE User="\L" /etc/init.d/pure-ftpd restart Ki kell deríteni az ftpuser userid-jét és a ftpgroup groupid-jét: cat /etc/passwd | grep ftpuser Valami ilyesmit láthatunk: ftpuser:x:1001:1001::/dev/null:/bin/false Ezek után felvehetjük a felhasználót: Egy felhasználó felvétele: mysql -u root -p INSERT INTO users (User, Password, Uid, Gid, Dir) VALUES ('joe', 'titok', 1001, 1001, '/home/virtual-ftp/joe'); ===== TLS ===== A TLS beállítása apt-get install openssl Készítenünk kell egy titkos kulcsot ami egyben tanúsítvány is: mkdir -p /etc/ssl/private openssl req -x509 -nodes -newkey rsa:1024 \ -keyout /etc/ssl/private/pure-ftpd.pem \ -out /etc/ssl/private/pure-ftpd.pem chmod 600 /etc/ssl/private/*.pem Beállítjuk a Pure-FTPd rendszert, hogy képes legyen használni a TLS-t: echo 2 > /etc/pure-ftdp/con/TLS A TLS kikapcsolása: echo 0 > /etc/pure-ftdp/con/TLS TLS és cleartext engedélyezése egyszerre: echo 1 > /etc/pure-ftdp/con/TLS ===== Anonymous FTP ===== ==== Az anonymous elérésről ==== Az anonymous felhasználó ha be van állítva egy FTP szerveren, akkor olyan felhasználók is hozzáférhetnek FTP szerverünkhöz, akinek nincs semmilyen hozzáférése. Tehát linuxos és virtuális felhasználóként sincs jelen a rendszerben. Ilyet általában akkor szoktunk használni, ha valamit szeretnénk közzé tenni, de nem weboldalon akarjuk ezt megtenni, mert nagy fájlokról van szó. Persze weben is közzé lehet tenni, de nagy fájlok közzétételére találták ki az FTP-t. Az anonymous felhasználó természetesen csak egy könyvtárhoz és persze azok alkönyvtáraihoz férhet majd hozzá. ==== Beállítások ==== Anonymous FTP szerverhez létre kell hozni egy felhasználót és egy csoportot akinek a jogaival az FTP szerver hozzáfér majd az anonymous felhasználók könyvtárához. Az anonymous felhasználók könyvtára lehet például a home könyvtárban egy ftp könyvtár. Az ftp csoport és az ftp felhasználó felvétele: groupadd ftp useradd -s /bin/false -d /home/ftp -m -c "anonymous FTP" -g ftp ftp Be kell állítanunk a szerver konfigurációjában, hogy engedélyezve van az anonymous. Ezt a tiltás tagadásával tehetjük meg. Szerkesszük az NoAnonymous állományt például az mcedit szövegszerkesztővel, vagy használjuk az echo parancsot: echo no > /etc/pure-ftpd/conf/NoAnonymous Az állomány tartalmát no-ra állítjuk. A /home/ftp könyvtár jogait be kell állítanunk: chmod 555 /home/ftp Ez anonymous felhasználóknak beálllíthatunk feltöltési lehetőséget is. Erre a célra az incoming nevű könyvtárat szoktuk létrehozni az ftp könyvtáron belül: mkdir -p /home/ftp/incoming chown ftp.nogroup /home/ftp/incoming chmod 311 /home/ftp/incoming Ha az anonymous felhasználók feltölteni is szeretnének, azt mindig egy „incoming” nevű könyvtárba engedélyezzük. Az incoming könyvtárnak a jogait ilyenkor úgy állítjuk be, hogy oda fel lehessen tölteni, de annak tartalma ne legyen látható, listázható. A fenti beállítások ezt teszik lehetővé. A beállítások után újra kell indítanunk az FTP szervert: systemctl restart pure-ftpd ==== Tesztelés ==== $ ftp localhost Connected to localhost. 220---------- Welcome to Pure-FTPd [privsep] [TLS] ---------- 220-You are user number 1 of 50 allowed. 220-Local time is now 18:17. Server port: 21. 220-IPv6 connections are also welcome on this server. 220 You will be disconnected after 15 minutes of inactivity. Name (localhost:mari): anonymous 230 Anonymous user logged in Remote system type is UNIX. Using binary mode to transfer files. ftp> Helytelen beállítás esetén: $ ftp localhost Connected to localhost. 220---------- Welcome to Pure-FTPd [privsep] [TLS] ---------- 220-You are user number 1 of 50 allowed. 220-Local time is now 17:51. Server port: 21. 220-This is a private system - No anonymous login 220-IPv6 connections are also welcome on this server. 220 You will be disconnected after 15 minutes of inactivity. Name (localhost:joska): Ha azt látjuk a bejelentkezéskor, hogy "220-This is a private system - No anonymous login" akkor nem a beállítások nem jók. Az "ls" paranccsal ellenőrizhetjük a könyvtár (/home/ftp) tartalmát: ftp> ls 200 PORT command successful 150 Connecting to port 44620 226-Options: -l 226 0 matches total ftp> Ez most üres. A szervert elhagyni: ftp> bye 221-Goodbye. You uploaded 0 and downloaded 0 kbytes. 221 Logout. A ftp> promt után a "help" parancs további utasításokat ad számunkra. ftp> help Commands may be abbreviated. Commands are: ! debug mdir qc send $ dir mget sendport site account disconnect mkdir put size append exit mls pwd status ascii form mode quit struct bell get modtime quote system binary glob mput recv sunique bye hash newer reget tenex case help nmap rstatus tick cd idle nlist rhelp trace cdup image ntrans rename type chmod lcd open reset user close ls prompt restart umask cr macdef passive rmdir verbose delete mdelete proxy runique ? ftp> ===== Egyéb beállítások ===== ==== Névfeloldás tiltása ==== echo yes > /etc/pure-ftpd/conf/DontResolve Ha szerverünk IP címe nem oldható fel host névvé, illetve domain névvé, akkor a /var/log/syslog fájlban a következőhöz hasonló hibaüzeneteket találunk: Sorry, invalid address given Ilyenkor lebeszélhetjük a Pure-FTPd szervert arról, hogy fel akarja oldani az IP címet valamilyen névvé. /etc/init.d/pure-ftpd restart Kapcsoló között meg kell jelenjen a következők valamelyike: -H --dontresolve ==== Chroot mindenki számára ==== echo yes > /etc/pure-ftpd/conf/ChrootEveryone ==== Home könyvtár automatikus létrehozása ==== echo yes > /etc/pure-ftpd/conf/CreateHomeDir ==== Aktívmód erőltetése ==== echo yes > /etc/pure-ftpd/conf/NATmode Ezzel a beállítással nem használhatjuk a passzívmódot. Kapcsolóval: -N ==== Passzívmód portjai ==== Passzívmódhoz beszoktuk korlátozni, milyen portokat használhat a Pure-FTPd. Például: echo "29799 29899" > /etc/pure-ftpd/conf/PassivePortRange Kapcsolóval: -p 41000:41100 ==== Kapcsolat irányának figyelése ==== apt install tcpick tcpick ==== Maximális kliensszám ==== Gondoljunk arra, hogy minden kapcsolathoz két port kell. echo 50 > /etc/pure-ftpd/conf/MaxClientsNumber ==== Bőbeszédű napló ==== echo 'yes' > /etc/pure-ftpd/conf/VerboseLog ==== Nem törölhető fájlok ==== echo yes > /etc/pure-ftpd/conf/KeepAllFiles ==== pure-ftpd-wrapper ==== A Debian alatt a pure-ftpd-wrapper teszi lehetővé, hogy a beállításokat a /etc/pure-ftpd/conf fájlból olvassa. Több parancsért lásd a pure-ftpd-wrapper kézikönyvet: man pure-ftpd-wrapper ===== Hibakezelés ===== ==== Jelenség alapján ==== * A kapcsolat lassan épül fel. A szerver szeretné feloldani az kliens IP címét névvé, de nem tudja. Oldjuk meg, hogy a kliens IP címe feloldható legyen. Ez megoldható a szerveren egy /etc/hosts fájl bejegyzéssel is. Vagy beszéljük le a szervert a névfeloldásról, lásd Beállítások fejezet. ==== Ellenőrzőlista ==== Mit ellenőrzünk és hogyan? - Fut-e az FTP szerver? - ps ax | grep pure-ftpd - nyitva van-e port - netstat -t -n -l - nmap localhost - Működik-e a szerveren helyben (localhost) az FTP elérés? - ftp localhost - Létezik-e az a felhasználó akinek a nevében be akarunk lépni? - Linuxos - cat /etc/passwd - Virtuális - cat /etc/pure-ftpd/pureftpd.passwd - Létezik a felhasználónak a könyvtára? - cat /etc/pure-ftpd/pureftpd.passwd és - ls /home/virtual-ftp/ kimenetét összehasonlítjuk - Feltételezve, hogy a felhasználónak a /home/virtual-ftp könyvtárban van könyvtára. - Naplófájlok - tail -f /var/log/syslog - tail -f /var/log/auth.log - Használható-e a hálózati kártya - ping 192.168.5.2 - Feltételezve, hogy ez a saját gépünk IP címe. - Van-e kapcsolat a belső hálózaton más gépekkel vagy a routerrel: - ping 192.168.5.1 - Feltételezve, hogy ez a router IP címe. - Van-e kapcsolat az Internet egy gépével - ping 152.66.115.35 - Van-e kapcsolat az Internet egy gépével: - ping kulsodomain.hu ===== FTP a tűzfalon ===== Szükségünk lesz a ip_conntrack_ftp modulra. Betöltéséről gondoskodjunk, mert nem töltődik be automatikusan. ===== Irodalom ===== * http://download.pureftpd.org/pub/pure-ftpd/doc/README.MySQL * http://hogyan.org/pureftpd-virtualis-felhasznalokkal-ubuntu-710 * http://www.howtoforge.com/pureftpd_mysql_virtual_hosting * * http://pure-ftpd.org