{"id":138,"date":"2018-10-21T15:03:04","date_gmt":"2018-10-21T13:03:04","guid":{"rendered":"http:\/\/blog.ilarionocentini.eu\/?p=138"},"modified":"2018-10-21T15:04:36","modified_gmt":"2018-10-21T13:04:36","slug":"aggiornare-ubuntu-server-da-14-04-a-16-04-su-cloud-server-aruba","status":"publish","type":"post","link":"https:\/\/blog.ilarionocentini.eu\/?p=138","title":{"rendered":"Aggiornare Ubuntu Server da 14.04 a 16.04 su cloud server Aruba"},"content":{"rendered":"<p>Dopo un paio d&#8217;anni dall&#8217;aggiornamento da 12.04 a 14.04 ( descritto <a href=\"http:\/\/blog.ilarionocentini.eu\/2016\/10\/04\/aggiornare-ubuntu-server-da-12-04-a-14-04-su-cloud-server-di-aruba\/\" target=\"_blank\" rel=\"noopener\">qui<\/a> ) mi sono deciso a fare l&#8217;aggiornamento seguente (il tempo passa&#8230;).<\/p>\n<p>Siccome ho avuto un paio di problemi che mi hanno richiesto un paio d&#8217;ore di tempo per risolverli, condivido qui la soluzione, cos\u00ec magari qualcun altro <img data-recalc-dims=\"1\" loading=\"lazy\" decoding=\"async\" data-attachment-id=\"151\" data-permalink=\"https:\/\/blog.ilarionocentini.eu\/?attachment_id=151\" data-orig-file=\"https:\/\/i0.wp.com\/blog.ilarionocentini.eu\/wp-content\/uploads\/2018\/10\/ubuntuupdt.jpg?fit=225%2C225&amp;ssl=1\" data-orig-size=\"225,225\" data-comments-opened=\"1\" data-image-meta=\"{&quot;aperture&quot;:&quot;0&quot;,&quot;credit&quot;:&quot;&quot;,&quot;camera&quot;:&quot;&quot;,&quot;caption&quot;:&quot;&quot;,&quot;created_timestamp&quot;:&quot;0&quot;,&quot;copyright&quot;:&quot;&quot;,&quot;focal_length&quot;:&quot;0&quot;,&quot;iso&quot;:&quot;0&quot;,&quot;shutter_speed&quot;:&quot;0&quot;,&quot;title&quot;:&quot;&quot;,&quot;orientation&quot;:&quot;0&quot;}\" data-image-title=\"ubuntuupdt\" data-image-description=\"\" data-image-caption=\"\" data-medium-file=\"https:\/\/i0.wp.com\/blog.ilarionocentini.eu\/wp-content\/uploads\/2018\/10\/ubuntuupdt.jpg?fit=225%2C225&amp;ssl=1\" data-large-file=\"https:\/\/i0.wp.com\/blog.ilarionocentini.eu\/wp-content\/uploads\/2018\/10\/ubuntuupdt.jpg?fit=225%2C225&amp;ssl=1\" class=\"alignright size-full wp-image-151\" src=\"https:\/\/i0.wp.com\/blog.ilarionocentini.eu\/wp-content\/uploads\/2018\/10\/ubuntuupdt.jpg?resize=225%2C225\" alt=\"\" width=\"225\" height=\"225\" srcset=\"https:\/\/i0.wp.com\/blog.ilarionocentini.eu\/wp-content\/uploads\/2018\/10\/ubuntuupdt.jpg?w=225&amp;ssl=1 225w, https:\/\/i0.wp.com\/blog.ilarionocentini.eu\/wp-content\/uploads\/2018\/10\/ubuntuupdt.jpg?resize=150%2C150&amp;ssl=1 150w\" sizes=\"auto, (max-width: 225px) 85vw, 225px\" \/>impiega quelle due ore in maniera pi\u00f9 interessante!<\/p>\n<p>Ho proceduto nella maniera classica a fare l&#8217;avanzamento di versione ma attenzione, prima di farlo leggete sotto.<\/p>\n<p>Collegato via ssh ho eseguito i seguenti comandi:<\/p>\n<pre class=\"brush: powershell; title: ; notranslate\" title=\"\"> sudo apt-get update \r\nsudo do-release-upgrade <\/pre>\n<p>Vi vengono fatte le solite domande, vengono disattivate le repositories di terze parte (che poi dovrete riattivare, come di norma) e tutto procede liscio, <strong>solo che dopo che il server ha fatto il reboot non riuscite pi\u00f9 a loggarvi con ssh<\/strong>, ping non risponde e tutti i servizi che avevate (e.g. web server) sono irraggiungibili.\u00a0 Ottimo risultato, no?<\/p>\n<p>Per fortuna Aruba mette a disposizione una <a href=\"https:\/\/kb.cloud.it\/computing\/console-di-ripristino\/accesso-ed-utilizzo-console-di-ripristino.aspx\">console di ripristino<\/a> , che vi permette di connettervi al server come se foste in locale. Li ho visto che il server era up e mi potevo loggare senza problemi, quindi ho dedotto che il problema fosse con i servizi di rete, ed infatti:<\/p>\n<p>Il comando:<\/p>\n<pre class=\"brush: powershell; title: ; notranslate\" title=\"\"> ifconfig <\/pre>\n<p>da come output<\/p>\n<pre class=\"brush: powershell; title: ; notranslate\" title=\"\"> \r\nlo        Link encap:Local Loopback  \r\n          inet addr:127.0.0.1  Mask:255.0.0.0\r\n          inet6 addr: ::1\/128 Scope:Host\r\n          UP LOOPBACK RUNNING  MTU:65536  Metric:1\r\n          RX packets:10886 errors:0 dropped:0 overruns:0 frame:0\r\n          TX packets:10886 errors:0 dropped:0 overruns:0 carrier:0\r\n          collisions:0 txqueuelen:0 \r\n          RX bytes:1164676 (1.1 MB)  TX bytes:1164676 (1.1 MB)\r\n <\/pre>\n<p>Dove \u00e8 finita la eth0 o chi per lei?<\/p>\n<p>Il problema \u00e8 che i nomi delle <a href=\"https:\/\/en.wikipedia.org\/wiki\/Consistent_Network_Device_Naming\">interfacce sono cambiati<\/a> , ma\u00a0 i file di configurazione della rete non lo sanno, ed infatti, se si guardano tutte le interfacce:<\/p>\n<pre class=\"brush: powershell; title: ; notranslate\" title=\"\"> ifconfig -a <\/pre>\n<p>il risultato \u00e8:<\/p>\n<pre class=\"brush: powershell; title: ; notranslate\" title=\"\">\r\nens32     Link encap:Ethernet  HWaddr 00:50:56:8b:f8:43\r\n          BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1\r\n          RX packets:509881 errors:0 dropped:3187 overruns:0 frame:0\r\n          TX packets:287604 errors:0 dropped:0 overruns:0 carrier:0\r\n          collisions:0 txqueuelen:1000\r\n          RX bytes:147738951 (147.7 MB)  TX bytes:500568621 (500.5 MB)\r\n\r\nens33     Link encap:Ethernet  HWaddr 00:50:56:8b:8c:a9\r\n          BROADCAST MULTICAST  MTU:1500  Metric:1\r\n          RX packets:0 errors:0 dropped:0 overruns:0 frame:0\r\n          TX packets:0 errors:0 dropped:0 overruns:0 carrier:0\r\n          collisions:0 txqueuelen:1000\r\n          RX bytes:0 (0.0 B)  TX bytes:0 (0.0 B)\r\n\r\nens34     Link encap:Ethernet  HWaddr 00:50:56:8b:62:86\r\n          BROADCAST MULTICAST  MTU:1500  Metric:1\r\n          RX packets:0 errors:0 dropped:0 overruns:0 frame:0\r\n          TX packets:0 errors:0 dropped:0 overruns:0 carrier:0\r\n          collisions:0 txqueuelen:1000\r\n          RX bytes:0 (0.0 B)  TX bytes:0 (0.0 B)\r\n\r\nlo        Link encap:Local Loopback\r\n          inet addr:127.0.0.1  Mask:255.0.0.0\r\n          inet6 addr: ::1\/128 Scope:Host\r\n          UP LOOPBACK RUNNING  MTU:65536  Metric:1\r\n          RX packets:11910 errors:0 dropped:0 overruns:0 frame:0\r\n          TX packets:11910 errors:0 dropped:0 overruns:0 carrier:0\r\n          collisions:0 txqueuelen:0\r\n          RX bytes:1330462 (1.3 MB)  TX bytes:1330462 (1.3 MB)\r\n\r\n<\/pre>\n<p>ovvero VMware mette a disposizione tre schede Ethernet, ma sono tutte down presumibilmente perch\u00e9 non hanno i dati di configurazione.<\/p>\n<p>In effetti \u00e8 cos\u00ec, infatti il comando:<\/p>\n<pre class=\"brush: powershell; title: ; notranslate\" title=\"\"> less \/etc\/network\/interfaces <\/pre>\n<p>evidenzia come ancora faccia\u00a0 ancora riferimento a <em>eth0<\/em>:<\/p>\n<pre class=\"brush: powershell; title: ; notranslate\" title=\"\">\r\n# This file describes the network interfaces available on your system\r\n# and how to activate them. For more information, see interfaces(5).\r\n\r\n# The loopback network interface\r\nauto lo\r\niface lo inet loopback\r\n\r\n# The primary network interface\r\nauto eth0\r\niface etho inet static\r\n        address 5.249.144.207\r\n        netmask 255.255.255.0\r\n        gateway 5.249.144.1\r\n        dns-nameservers 62.149.128.4 62.149.132.4\r\n\r\n<\/pre>\n<p>Ovviamente voi avrete il vostro indirizzo IPv4 invece che 5.249.144.207 .<\/p>\n<p>Ora basta sostituire <em>ens32<\/em> a <em>eth0<\/em>, in modo da ottenere:<\/p>\n<p>&nbsp;<\/p>\n<pre class=\"brush: powershell; title: ; notranslate\" title=\"\">\r\n# This file describes the network interfaces available on your system\r\n# and how to activate them. For more information, see interfaces(5).\r\n\r\n# The loopback network interface\r\nauto lo\r\niface lo inet loopback\r\n\r\n# The primary network interface\r\nauto ens32\r\niface ens32 inet static\r\n        address 5.249.144.207\r\n        netmask 255.255.255.0\r\n        gateway 5.249.144.1\r\n        dns-nameservers 62.149.128.4 62.149.132.4\r\n\r\n<\/pre>\n<p>Il mio suggerimento \u00e8, prima di fare l&#8217;avanzamento di versione, aggiungete in <em>\/etc\/network\/interfaces<\/em> anche la sezione auto <em>ens32 <\/em>. Non ho fatto il test, ma suppongo che funzioni.<\/p>\n<p>Fate ripartire la macchina e i servizi di rete ripartiranno e potrete collegarvi con ssh come di consueto.<\/p>\n<p>Successivamente ho testato i miei web server che girano con WordPress sotto apache2 sul mio server e mi sono accorto che uno di essi non rispondeva. O meglio, faceva visulaizzare una pagina bianca.<\/p>\n<p><strong>Il problema qui \u00e8 che Ubuntu 16.04 intruduce PHP7 in sostituzione di PHP5.6, e che PHP7 non \u00e8 backward compatible con PHP5.6<\/strong>, e quindi alcuni plugin o temi di WordPress che non fossero aggiornati potrebbero dare problemi.<\/p>\n<p>Nel mio caso, guardando il log degli errori usando il comando :<\/p>\n<pre class=\"brush: powershell; title: ; notranslate\" title=\"\"> tailf \/var\/log\/apache2\/error.log <\/pre>\n<p>ho visto che, ogni volta che provavo a caricare il sito, ottenevo il seguente errore:<\/p>\n<pre class=\"brush: powershell; title: ; notranslate\" title=\"\">\r\n&#x5B;Sat Oct 20 14:17:13.390786 2018] &#x5B;:error] &#x5B;pid 1407] &#x5B;client 62.156.8.161:60501] PHP Fatal error:  Uncaught Error: Call to undefined function mysql_real_escape_string() in \/var\/www\/federicobindi\/wp-content\/plugins\/statpress-visitors\/statpress.php:305\\nS\r\n<\/pre>\n<p>Infatti il plugin <em>statpress-visitor<\/em> usava la funzione <em>mysql_real_escape_string()<\/em> invece che <em>mysql<strong>i<\/strong>_real_escape_string() <\/em>(ovvero si inserisce la &#8220;i&#8221;) e poich\u00e9 PHP7 non suppporta pi\u00f9 la vecchia sintassi delle funzioni mysql il plugin bloccava il sito.<\/p>\n<p>Nel mio caso ho editato il file incriminato inserendo la &#8220;i&#8221; ove necessario ed il sito \u00e8 ripartito. Ovviamente subito dopo ho rimosso il plugin, che in effetti era obsoleto.<\/p>\n<p>ATTENZIONE: in molti blog vi suggeriscono di risolvere questo tipo di problemi reinstallando la versione di PHP5.6 al posto del PHP7.0. E&#8217; una pessima idea, magari risolvete il problema specifico, ma vi ritrovate con una versione obsoleta e che presto non verr\u00e0 manutenuta, e con il rischio di ritrovarvi con molti pi\u00f9 problemi nel medio periodo.<\/p>\n","protected":false},"excerpt":{"rendered":"<p>Dopo un paio d&#8217;anni dall&#8217;aggiornamento da 12.04 a 14.04 ( descritto qui ) mi sono deciso a fare l&#8217;aggiornamento seguente (il tempo passa&#8230;). Siccome ho avuto un paio di problemi che mi hanno richiesto un paio d&#8217;ore di tempo per risolverli, condivido qui la soluzione, cos\u00ec magari qualcun altro impiega quelle due ore in maniera &hellip; <a href=\"https:\/\/blog.ilarionocentini.eu\/?p=138\" class=\"more-link\">Leggi tutto<span class=\"screen-reader-text\"> &#8220;Aggiornare Ubuntu Server da 14.04 a 16.04 su cloud server Aruba&#8221;<\/span><\/a><\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"jetpack_post_was_ever_published":false,"_jetpack_newsletter_access":"","_jetpack_dont_email_post_to_subs":false,"_jetpack_newsletter_tier_id":0,"_jetpack_memberships_contains_paywalled_content":false,"_jetpack_memberships_contains_paid_content":false,"footnotes":"","jetpack_publicize_message":"","jetpack_publicize_feature_enabled":true,"jetpack_social_post_already_shared":true,"jetpack_social_options":{"image_generator_settings":{"template":"highway","default_image_id":0,"font":"","enabled":false},"version":2}},"categories":[8],"tags":[5,22,6,3],"class_list":["post-138","post","type-post","status-publish","format-standard","hentry","category-tech","tag-14-04","tag-16-04","tag-aruba","tag-ubuntu"],"jetpack_publicize_connections":[],"jetpack_featured_media_url":"","jetpack_sharing_enabled":true,"jetpack_shortlink":"https:\/\/wp.me\/p7LlHs-2e","jetpack-related-posts":[],"_links":{"self":[{"href":"https:\/\/blog.ilarionocentini.eu\/index.php?rest_route=\/wp\/v2\/posts\/138","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/blog.ilarionocentini.eu\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/blog.ilarionocentini.eu\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/blog.ilarionocentini.eu\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/blog.ilarionocentini.eu\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=138"}],"version-history":[{"count":12,"href":"https:\/\/blog.ilarionocentini.eu\/index.php?rest_route=\/wp\/v2\/posts\/138\/revisions"}],"predecessor-version":[{"id":152,"href":"https:\/\/blog.ilarionocentini.eu\/index.php?rest_route=\/wp\/v2\/posts\/138\/revisions\/152"}],"wp:attachment":[{"href":"https:\/\/blog.ilarionocentini.eu\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=138"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/blog.ilarionocentini.eu\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=138"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/blog.ilarionocentini.eu\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=138"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}