{"id":443,"date":"2009-11-14T00:43:31","date_gmt":"2009-11-13T23:43:31","guid":{"rendered":"http:\/\/blog.benny-baumann.de\/?p=443"},"modified":"2009-11-14T00:45:40","modified_gmt":"2009-11-13T23:45:40","slug":"server-migriert","status":"publish","type":"post","link":"https:\/\/blog.benny-baumann.de\/?p=443","title":{"rendered":"Server migriert!"},"content":{"rendered":"<p>Es ist vollbracht!<!--more--><\/p>\n<p>Ja, es ist vollbracht: Endlich L\u00c4UFT der neue Server, jegliche Dienste sind umgezogen UND es gibt erstmal keine offensichtlichen Fehler mehr &#8230;<\/p>\n<p>Die eigentliche Umzugsarbeit war nach nicht mal einer Stunde erledigt und auch das Umziehen der \u00fcber 20 Domains war in etwa 15 Minuten getant (das Aktualisieren des DNS-Caches d\u00fcrfte nicht mal ins Gewicht gefallen sein, da jegliche Domains eh nur 10 Minuten gecacht werden sollen). <\/p>\n<p>Aber gut: Warum melde ich mich dann erst ~2 Stunden sp\u00e4ter? Kurz gesagt: Weil FCGID der Meinung war, Scripte mit kuriosesten Berechtigungsproblemen nicht ausf\u00fchren zu wollen. Die Ursache, dass es an den Rechten liegt, ist bei Fehlermeldungen wie<\/p>\n<pre lang=\"text\">[Sat Nov 14 00:25:59 2009] [warn] (104)Connection reset by peer: mod_fcgid: read data from fastcgi server error.\r\n[Sat Nov 14 00:25:59 2009] [error] [client 65.55.207.101] Premature end of script headers: index.php<\/pre>\n<p>den von Aussagekraft strotzenden Log-Eintr\u00e4gen von suexec (apache2-suexec-custom) a la<\/p>\n<pre lang=\"text\">[2009-11-13 23:46:32]: uid: (2059\/vu2059) gid: (2059\/vu2059) cmd: php5-fcgi-starter\r\n[2009-11-13 23:46:32]: target uid\/gid (2059\/2059) mismatch with directory (2018\/2018) or program (2018\/2018)<\/pre>\n<p>ja wohl jedem Blinden ersichtlich sein. Oder t\u00e4usche ich mich da. Na gut: Es gab da nun dieses <a href=\"http:\/\/www.isp-control.net\/forum\/thread-5610.html?highlight=howto\">HauZu<\/a>, was die n\u00f6tigen Schritte auch soweit recht gut beschrieben hatte, jedoch genau beim wichtigsten Schritt EXTREM patzte: Setzen der BErechtigungen f\u00fcr FastCGI.<\/p>\n<p>Korrigiert m\u00fcsste das Script lauten:<\/p>\n<pre lang=\"bash\">#!\/bin\/bash\r\n#\r\n# PROCESS DIRECTORY RIGHTS (OWNERSHIP & CHMOD)\r\n#\r\n# !!!! Edit path to mysql.cnf file !!!!\r\nmycnf=\/root\/mysql.cnf\r\n\r\n# sample mysql.cnf looks like this:\r\n# [client]\r\n# user=user_for_ispcp_database_usualy_root\r\n# password=password_of_user\r\n\r\nfor domain_id in `echo \"SELECT domain_id FROM ispcp.domain\" | mysql --defaults-file=$mycnf -s`;\r\ndo\r\nuid=`echo \"SELECT domain_uid FROM ispcp.domain WHERE domain_id='$domain_id'\" | mysql --defaults-file=$mycnf -s`;\r\ngid=`echo \"SELECT domain_gid FROM ispcp.domain WHERE domain_id='$domain_id'\" | mysql --defaults-file=$mycnf -s`;\r\ndmn=`echo \"SELECT domain_name FROM ispcp.domain WHERE domain_id='$domain_id'\" | mysql --defaults-file=$mycnf -s`;\r\necho \"===========================================================\";\r\necho \" $dmn\";\r\necho \"===========================================================\";\r\n\r\n# process ftp\r\necho \"UPDATE \\`ispcp\\`.\\`ftp_group\\` SET \\`gid\\`='$gid' WHERE \\`groupname\\`='$dmn'\" | mysql --defaults-file=\/root\/mysql.cnf -s\r\necho \"UPDATE \\`ispcp\\`.\\`ftp_users\\` SET \\`uid\\`=$uid, \\`gid\\`='$gid' WHERE \\`userid\\` like '%@$dmn'\" | mysql --defaults-file=\/root\/mysql.cnf -s\r\nchown -R vu$uid:vu$gid \/var\/www\/virtual\/$dmn\r\n\r\nchmod 770 \/var\/www\/virtual\/$dmn\r\nchown vu$uid:www-data \/var\/www\/virtual\/$dmn\r\n\r\nchown -R vu$uid:www-data \/var\/www\/virtual\/$dmn\/backups\r\nchmod 770 \/var\/www\/virtual\/$dmn\/backups\r\n\r\nchown -R vu$uid:vu$gid \/var\/www\/virtual\/$dmn\/cgi-bin\r\nchmod 755 \/var\/www\/virtual\/$dmn\/phptmp\r\n\r\nchown -R vu$uid:vu$gid \/var\/www\/virtual\/$dmn\/errors\r\nchmod 775 \/var\/www\/virtual\/$dmn\/errors\r\n\r\nchown -R vu$uid:vu$gid \/var\/www\/virtual\/$dmn\/htdocs\r\nfind \/var\/www\/virtual\/$dmn\/htdocs -type d -exec chmod 775 {} \\;\r\n\r\nchown vu$uid:www-data \/var\/www\/virtual\/$dmn\/.ht*\r\nchown vu$uid:www-data \/var\/www\/virtual\/$dmn\/.svn*\r\nchmod 640 \/var\/www\/virtual\/$dmn\/.ht*\r\n\r\nchown -R vu$uid:www-data \/var\/www\/virtual\/$dmn\/logs\r\nchmod 770 \/var\/www\/virtual\/$dmn\/logs\r\n\r\nchown -R vu$uid:www-data \/var\/www\/virtual\/$dmn\/phptmp\r\nchmod 770 \/var\/www\/virtual\/$dmn\/phptmp\r\n\r\nchown -R vu$uid:vu$gid \/var\/www\/fcgi\/$dmn\r\nchmod 755 \/var\/www\/fcgi\/$dmn\r\nchmod 755 \/var\/www\/fcgi\/$dmn\/php5-fcgi-starter\r\n\r\nchown -R vmail:mail \/var\/mail\/virtual\/*\r\nsleep 1\r\n\r\ndone<\/pre>\n<p>Danach noch etwas zwecks enabledten Mods spielen, Sto\u00dfgebet gen Himmel und einen Restart des Apachen &#8230; Mit etwas Gl\u00fcck funktioniert es danach &#8230; Alternativ aus dem engine\/setup-Verzeichnis das ispcp-update-Script ausf\u00fchren (Im Falle, dass er Module nicht findet, in das setup-Verzeichnis vorher wechseln). Dort Punkt 9 ausw\u00e4hlen, dann baut er jegliche Nutzer neu auf. Danach dann dieses Permission-Update-Script starten.<\/p>\n<p>Da hatte ich mit Postfix, MySQL, und den zahlreichen anderen Diensten wirklich weniger Probleme.<\/p>\n<p>Naja. Wird Zeit, dass die bei ispCP endlich die Server-Migration als Default-Feature upstream einpflegen!<\/p>\n<p class=\"wp-flattr-button\"><a href=\"https:\/\/blog.benny-baumann.de\/?flattrss_redirect&amp;id=443&amp;md5=8778be77b412940f6c1a96f1a1a71655\" title=\"Flattr\" target=\"_blank\"><img src=\"http:\/\/blog.benny-baumann.de\/wp-content\/plugins\/flattr\/img\/flattr-badge-large.png\" srcset=\"http:\/\/blog.benny-baumann.de\/wp-content\/plugins\/flattr\/img\/flattr-badge-large.png\" alt=\"Flattr this!\"\/><\/a><\/p>","protected":false},"excerpt":{"rendered":"<p>Es ist vollbracht!<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"ngg_post_thumbnail":0,"footnotes":""},"categories":[4],"tags":[156,10,81,21,346,80],"class_list":["post-443","post","type-post","status-publish","format-standard","hentry","category-server","tag-apache","tag-debian","tag-ispcp","tag-php","tag-server","tag-umzug"],"_links":{"self":[{"href":"https:\/\/blog.benny-baumann.de\/index.php?rest_route=\/wp\/v2\/posts\/443","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/blog.benny-baumann.de\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/blog.benny-baumann.de\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/blog.benny-baumann.de\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/blog.benny-baumann.de\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=443"}],"version-history":[{"count":3,"href":"https:\/\/blog.benny-baumann.de\/index.php?rest_route=\/wp\/v2\/posts\/443\/revisions"}],"predecessor-version":[{"id":445,"href":"https:\/\/blog.benny-baumann.de\/index.php?rest_route=\/wp\/v2\/posts\/443\/revisions\/445"}],"wp:attachment":[{"href":"https:\/\/blog.benny-baumann.de\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=443"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/blog.benny-baumann.de\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=443"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/blog.benny-baumann.de\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=443"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}