Tuesday, June 24, 2014

Enable compression and leverage browser caching of your site

Have you done page speed test of your web pages lately? There is a nice tool developed by google for other developers and webmasters which can help gain information whether there is space for speed optimizations of your webpages. Tool is called PageSpeed Insights and you can gather valuable information doing this test. 
  



Information you gather from analysis will point you in right direction what can be optimized on you pages. These factors probably play some role in overall SERP (ranking of your page on google) to what degree nobody know but if there is even little edge in SEO, and it's quick to optimize, why not do it? There is nothing to lose and a lot of to gain in terms of page speed and consequently in user experince which a valued thing in eyes of google. (Why else show estimation of user experince of your page analysis?)

Here we will do quick speed optimization of browser caching and gzip/deflate compression.

These two play big role in overall speed estimation as you will see by testing after you've optimized your pages.

Leverage browser caching 

Idea behind browser caching is to assign expiration date of concrete resources (commonly grouped by file type) on web server and when user sends request to server asking for a specific resource browser caches that request and when user sends another request to server, if resource expiration date has not yet expired browser will try to load that resource from local browser cache instead of requesting transmission from server. This in turn reduces need for communication between client-server and loads pages much faster. Also caching reduces server bandwidth which is important for high traffic sites.

In order to leverage browser caching you should edit your .htaccess file in root directory of your site.
Of course we assume your hosting server supports this. If there is no .htaccess files create it and enter the following:


ExpiresActive on
ExpiresDefault A0

# 1 YEAR - doesn't change often
<FilesMatch "\.(flv|ico|pdf|avi|mov|ppt|doc|mp3|wmv|wav)$">
ExpiresDefault A29030400
</FilesMatch>

# 1 WEEK - possible to be changed, unlikely
<FilesMatch "\.(jpg|jpeg|png|gif|swf|js|css)$">
ExpiresDefault A604800
</FilesMatch>

# 3 HOUR - core content, changes quickly
<FilesMatch "\.(txt|xml)$">
ExpiresDefault A10800
</FilesMatch>

Numbers are expiration time in seconds. If you want you can change this to suit your needs.

Now that you've saved .htaccess file on your server, if supported, your server will assign to requests expiration tag of resources representing file types we've added.

And that's it "leverage browser caching" done! Now we step into gzip/deflate compression.

Enable gzip/deflate compression on your site

gzip/deflate compression is a method of compressing requests requested resources from web server. What happens is that before sending resources to client web server compresses web page in gzip or deflate compression and then sends it. This in turn "lightens" the page (size is smaller) and again helps client in terms of page load. Of course client or commonly browser decompresses that page and shows it to the user in original way. So it's a kind of transformation. 

To do this and enable compression of your web site content again open .htaccess file and add before caching options following (we'll be using deflate compression):



AddOutputFilterByType DEFLATE text/plain
AddOutputFilterByType DEFLATE text/html
AddOutputFilterByType DEFLATE text/xml
AddOutputFilterByType DEFLATE text/css
AddOutputFilterByType DEFLATE application/xml
AddOutputFilterByType DEFLATE application/xhtml+xml
AddOutputFilterByType DEFLATE application/rss+xml
AddOutputFilterByType DEFLATE application/javascript
AddOutputFilterByType DEFLATE application/x-javascript 


Save .htaccess file and you're ready to test your page speed, check out page speed insights and let me know of your results in comments!
 
      


Enable userdir apache module on Ubunty

What is userdir? 

userdir is module on apache2 web server that enables users (apart from root user) on multiuser system like linux, accessible public directory on web server. For every user on the system there is corresponding address. To be more precise if there are users, john, peter on system corresponding addresses would be: 

http://hostname/~john/    --> mapped to /home/john/public_html/
http://hostname/~peter/   --> mapped to /home/peter/public_html/

So every user on the system can have their own web site.

Why do I need apache2 userdir mod?

If you have multiple web projects you are working on and don't want to bother with root account all the time userdir is the way to go. 

Ok so how do I enable this userdir mod? 

If you have apache2 web server installed, then userdir module is available, you just have to enable it. To do this, open your terminal (CTRL + ALT + T) and enter following command: 

sudo  a2enmod userdir

This command will enable userdir module, now you need to create public_html directory under your 'home' path. Your home path will be /home/yourusername/ so that's where you create new directory
like so: 

mkdir public_html

and add privileges 

chmod 755 public_html

After this step you need to restart your apache2 server so the changes are applied. 

sudo service apache2 restart

Ok now when you create something in public_html dir you can access it via web browser. So create file:

index.html and fill it with some text. It will be accessible via http from web browser:

http://localhost/~youusername/index.html

That's nice but php is not interpreting my code, what to do? 

By default php interpreter is disabled from userdirs so you'll have to enable that as well. To do so you have to edit php5.conf file:

sudo gedit /etc/apache2/mods-enabled/php5.conf

and you'll see something like this: 


<FilesMatch ".+\.ph(p[345]?|t|tml)$">

    SetHandler application/x-httpd-php

</FilesMatch>

<FilesMatch ".+\.phps$">

    SetHandler application/x-httpd-php-source

    # Deny access to raw php sources by default

    # To re-enable it's recommended to enable access to the files

    # only in specific virtual host or directory

    Order Deny,Allow

    Deny from all

</FilesMatch>

# Deny access to files without filename (e.g. '.php')

<FilesMatch "^\.ph(p[345]?|t|tml|ps)$">

    Order Deny,Allow

    Deny from all

</FilesMatch>



# Running PHP scripts in user directories is disabled by default

#

# To re-enable PHP in user directories comment the following lines

# (from <IfModule ...> to </IfModule>.) Do NOT set it to On as it

# prevents .htaccess files from disabling it.

<IfModule mod_userdir.c>

    <Directory /home/*/public_html>

        php_admin_flag engine Off

    </Directory>

</IfModule>


Comment last 5 lines (from <IfModule> .. </IfModule>)  and you should get:


<FilesMatch ".+\.ph(p[345]?|t|tml)$">

    SetHandler application/x-httpd-php

</FilesMatch>

<FilesMatch ".+\.phps$">

    SetHandler application/x-httpd-php-source

    # Deny access to raw php sources by default

    # To re-enable it's recommended to enable access to the files

    # only in specific virtual host or directory

    Order Deny,Allow

    Deny from all

</FilesMatch>

# Deny access to files without filename (e.g. '.php')

<FilesMatch "^\.ph(p[345]?|t|tml|ps)$">

    Order Deny,Allow

    Deny from all

</FilesMatch>



# Running PHP scripts in user directories is disabled by default

#

# To re-enable PHP in user directories comment the following lines

# (from <IfModule ...> to </IfModule>.) Do NOT set it to On as it

# prevents .htaccess files from disabling it.

#<IfModule mod_userdir.c>

#    <Directory /home/*/public_html>

#        php_admin_flag engine Off

#    </Directory>

#</IfModule>


Now save the changes (CTRL +S)  and restart apache2 web server again.

sudo service apache2 restart

Now your php files under userdir will be interpreted by php interpreter.  More information on apache2 userdir can be found http://httpd.apache.org/docs/2.2/mod/mod_userdir.html.



Highlight code on blogger


So if you've run into this post, you must be wondering how to apply code highlighting on popular blogging platform blogger.com and you're at the right place. Before we go to instructions here are some examples of highlighted code just for motivation. If you like it, you can proceed and integrate this handy feature.  
some random c code ...

// little c code
int main(int argc, char argv**) {
 int i;
 for(i = 0; i <= 99; i++)
   fprintf(stdout, "%d\n", i);

 return 0;
}

Or some php code:


require_once 'Zend/Uri/Http.php';

namespace Location\Web;

interface Factory
{
    static function _factory();
}

abstract class URI extends BaseURI implements Factory
{
    abstract function test();

    /**
     * Returns a URI
     *
     * @return URI
     */
    static public function _factory($stats = array(), $uri = 'http')
    {
        echo __METHOD__;
        $uri = explode(':', $uri, 0b10);
        $schemeSpecific = isset($uri[1]) ? $uri[1] : '';
        $desc = 'Multi
line description';

        // Security check
        if (!ctype_alnum($scheme)) {
            throw new Zend_Uri_Exception('Illegal scheme');
        }

        return [
            'uri'   => $uri,
            'value' => null,
        ];
    }
}
some html code ...

<!DOCTYPE html>
<title>Title</title>

<style>body {width: 500px;}</style>

<script type="application/javascript">
  function $init() {return true;}
</script>

<body>
  <div checked="" class="title" id="title">
Title</div>
<!-- here goes the rest of the page -->
</body>


css code ...

@media screen and (-webkit-min-device-pixel-ratio: 0) {
  body:first-of-type pre::after {
    content: 'highlight: ' attr(class);
  }
  body {
    background: linear-gradient(45deg, blue, red);
  }
}

If you like what you see, and want to implement this feature, follow few simple steps (by the way it's very easy):

On the left menu on your blogger account go to templates click "edit html" just before closing of:
</header> tag add 3 lines (2 comment lines are there just to remind you what you've added and where, in case you what to remove code highlighting later...)


<!-- highlight.js -->
<link href='http://yandex.st/highlightjs/8.0/styles/default.min.css' rel='stylesheet'/>
 <script src='http://yandex.st/highlightjs/8.0/highlight.min.js'/>
<script>hljs.initHighlightingOnLoad();</script>
<!-- / highlight.js -->


click "save template" and you're done.

Ok what now? How do I use code highlighting?

It turn out it's quite easy, when you want to highlight some code, first you write it in WYSIWYG editor like you normally would and then switch to HTML mode of editing post, and put around your code html tags like this:

<pre><code> your code ... </pre></code>


And your code will be heightlighted. If you want to specify what language you use in your code, that can be done like this:


<pre><code class='hljs python'> your code here ... </pre></code>


where instead of python you add language of your choosing. Here are some possible languages of highlight.js lib:

python
c
cpp
java
objectivec
cs (C#)
sql
lisp
xml
css
scala
go
javascript
json
bash
...

There are others as well. For full list of code markup highlighting check out: highlightjs test page
Also visit http://highlightjs.org/ for more info and details about some advanced features of this library.

happy coding!   

Sunday, June 22, 2014

Ubuntu 13.10 cursor blinking and printscreen multiple screens

After upgrading to Ubuntu 13.10 you may have a problem with cursor blinking all the time this upgrade also affects printscreen it renders as if you have two monitors. So what's the problem with cursor blinking and printscreen multiple monitors?

Well it's due to multiple monitor settings, to fix this you have to go to settings -> displays and turn of unknown display. Here is how to do that:

1. select unknown display (click on it)

Here is the image of unknown display selected:


After you've selected unknown display, turn it off by switching ON/OF scroll option. When you do that here is how your settings window should look:


That's it now your print screen should work fine, there should not be any multiple windows and cursor blinking will stop. That's it, you're done.

If you have problem with Ubuntu 13.10 vertical scrolling check out this post: Ubuntu 13.10 vertical scrolling fix

Enable edge vertical scrolling in ubuntu 13.10 and 14.04

First thing you notice after upgrade to Ubuntu 13.10 is that edge vertical scrolling doesn't work, to be precise there is still option to make it work, just by default this isn't the case anymore. So what should I do to return my edge vertical scrolling option?

Well it turns out that it's really simple to make it work again, what you have to do is to uncheck two finger scroll under settings -> Mouse and Touchpad

Here is the image before unchecking two finger scrolling option, to enable edge vertical scrolling uncheck two finger scroll option.


By the way two finger scroll option means that you scroll by fixing one finger on touch pad  and using other to scroll, anywhere on the tuchpad surface. This actually can work very well so before switching back, give it a chance! 

Saturday, June 21, 2014

Recover lost files from usb stick


Sometimes when we make a mistake and accidentally delete files from usb drive or do a partition format of usb, most people believe that it's for good and that we should let go, but in some cases files can be successfully recover and the day could be saved!

Generally there are two cases we could try recovery and hope for the best are:

1. When files were removed
2. We've done flash disk (flash usb stick) format [quick format only]
3. USB Flash stick format was performed [quick format] and some other files were written afterwards.
If you are happy user of Ubuntu OS (or unix in general), and  your case is one of the 3. files most likely could be recovered. In case 1 and 2 files can most certainly be recovered and in case 3 we depend on luck (we hope that files that were copied afterwards were not written on sectors containing files we are hoping to recover.

To do this under linux there is one wonderful little program called foremost which does the job.
Here is a download link: http://foremost.sourceforge.net/

Under Ubuntu you can install this via aptitude, to install type following in command shell:

$ sudo apt-get install foremost

Now that you have this program ready and installed, you can start recovery of your lost files.
For more info on command options of this wonderful software check out man pages

$ man foremost 

Ok now in order to recover lost files all you need to do is plugin you usb flash stick, find right device mapping and start recovery. To find usb device mapping (if you've already mounted usb flash stick onto file system) type

$ sudo mount 

Output should show mapping of all devices to corresponding paths on files system. For me when I insert flash usb, mapping of devices is /dev/sdc

Now to recover all lost files using foremost you enter following command:

$ sudo foremost -i /dev/sdc -o /media/recovery/ 

If you want to recover specific files (naturally faster) add -t flag with specified file type:
For instance if you want to recover all of office files like *.ppt *.doc other Word or Access files
you can use following command

$ sudo foremost -i /dev/sdc -o /media/recovery/ -t ole

Upon execution program will start to recover desired files and progress will be shown in terminal
like so:

Processing: /dev/sdc
|*****************************************************************************|

Now that file recovery is done you look into the magic hat and see what it brings you, if you're in luck (for case 3.) files should be recovered under /media/recovery/ path. Keep in mind that foremost runs under root privileges so you'll have to change the ownership of recovery folder in order to copy recovered files. Under recovery folder you'll see audit.txt file which contains results of foremost recovery. Output looks something like this:

Foremost version 1.5.7 by Jesse Kornblum, Kris Kendall, and Nick Mikus
Audit File

Foremost started at Sat Jun 21 22:37:38 2014
Invocation: foremost -i /dev/sdc -o /media/ddr/recover/ -t ole 
Output directory: /media/ddr/recover
Configuration file: /etc/foremost.conf
------------------------------------------------------------------
File: /dev/sdc
Start: Sat Jun 21 22:37:38 2014
Length: 7 GB (8004304896 bytes)

Num Name (bs=512)       Size File Offset Comment 

0: 00396638.ole       8 KB  203079117  
1: 00397608.ole       8 KB  203575709  
2: 00556587.ole     378 KB  284972979  
3: 10493472.xls      41 KB 5372657664  
4: 14399168.doc     396 KB 7372374016  
5: 14399968.doc      83 KB 7372783616  
6: 14400160.doc      45 KB 7372881920  
7: 14400672.doc     134 KB 7373144064  
8: 14400960.doc      18 KB 7373291520  
9: 14401056.doc      23 KB 7373340672  
10: 15154976.doc      78 KB 7759347712  
11: 15155200.doc      79 KB 7759462400  
12: 15155424.doc      80 KB 7759577088  
13: 15155648.doc      82 KB 7759691776  
14: 15155872.doc      85 KB 7759806464  
15: 15156096.doc      87 KB 7759921152  
16: 15156320.doc      87 KB 7760035840  
17: 15156608.doc      89 KB 7760183296  
18: 15156832.doc      90 KB 7760297984  
19: 15157056.doc      90 KB 7760412672  
20: 15157280.doc      90 KB 7760527360  
21: 15157504.doc      90 KB 7760642048  
22: 15157728.doc      91 KB 7760756736  
23: 15157952.doc      91 KB 7760871424  
24: 15158176.doc      92 KB 7760986112  
25: 15158400.doc      93 KB 7761100800  
26: 15158624.doc      93 KB 7761215488  
27: 15543062.ole       8 KB 7958048205  
28: 15544040.ole       8 KB 7958548893  
Finish: Sat Jun 21 22:43:38 2014

29 FILES EXTRACTED

ole:= 29
------------------------------------------------------------------

So I've been able to extract 29 ole files which is great considering I was in case 3 scenario of this tutorial.

Also keep in mind that best way to copy recovered files is via command shell using cp command and view them later as standard user. (Because when trying to access file directory in my case /recovery/doc gui based file system navigator shows as if doc is not a directory and it is, you can see it via terminal. To workaround this you copy files via terminal to some other location like:

we are at /recovery/doc/ path.

$ sudo mkdir -p /home/username/recovered_files/
$ sudo cp *.* /home/username/recovered_files/

And that's it now all of your recovered files are in /home/username/recovered_files directory (substitute username with your own username)

Hope this helps I've done some amazing job at recovery using this simple method, it's efficient and it works well.

Good luck at file recovery and check out post on how to make a bootable usb stick under linux




Make bootable usb under linux

Intro 

if you want to create bootable usb stick (pen drive) keep reading, first we will present a general overview of procedure and then step by step instructions with possible errors you could bump into along the road. Users who have done format of their usb flash sticks should proceed to part 2 of this tutorial (creating bootable usb stick using unetbootin

The general procedure 

requirements:
1. usb flash stick with sufficient memory space.
2. iso image of windows or linux depending what OS you want install on host machine.

general procedure:
1. Format your usb stick with FAT32 , FAT file system. (see formating usb stick under linux bellow for instructions how to do that)
2. using unetbootin program make your usb flash stick bootable.
3. boot from usb stick (see boot from usb)
4. install windows or linux OS (this is quite straight forward process once you boot from usb)

possible errors:
1. ISO file is corrupted and you need to download another ISO file image.
2. unetbootin finished creating bootable flash stick, but flash stick won't boot
        2a. If there is a boot manager screen of unetbootin but it won't boot, it's probably problem with ISO file so you need to find another working ISO image and redo the procedure. 
        2b. If there is no boot manager screen poping then usb is not bootable, try another usb port.



Format usb stick under linux 

There are a few ways to make this work, here are some of them starting from the easiest method. 

Format usb stick under linux Ubuntu

This method works for ubuntu distro of linux (they made it very simple *user friendly, hence it's so popular)
1. plug in you usb flash stick 
2.  find your disks application and open it. Here is how it looks like: 
click on disks icon

3. When you open disks app find your usb flash disk under "disk drives" like on image bellow:
4. Important: In order to format you usb flash drive it shouldn't be mounted onto file-system, by default it is, so you need to click stop sign and this will unmount usb flash drive from file system. You will know it's unmounted by checking In use status, see the image (it should say In use: NO) 

5. Click that settings icon like pointed on image under step 3. and select "FORMAT..." option. This will bring new window and with format options, see next image
6. Under erase leave it quick (don't overwrite existing data) 
Slow means that system will do full format in sense that every single bit of memory will be overwritten with zero. under Type select "compatible with all system devices (FAT)" and fill in last field Name whatever you want, it's name of your flash stick with you mount it. Next you click format and prompt window will ask you whether you are sure you want to format and you hit "FORMAT" 
(tip bellow explains that if you use quick format of data previously saved can be extracted with some recovery tools unless overwritten, so if you want to give your flash to another user consider full format. For our use this will not be necessary.)

Here is an image of prompt dialog: 
Click format button
If you've selected quick format process should finish in a second. And that should be it, you're done with format of your usb stick. This is the the easiest way and it's for users using Ubuntu linux distro.
If you're not using Ubuntu, bellow is another way via command shell. But before that, if you don't unmount your usb from file system, the error will be presented like on image bellow: 
If this happens you've forgot to unmount your usb, go back to step 4. 

Format usb stick under linux (In general all distros)

Before we could format usb stick, we need to find device path mapping of our usb flash stick. To do this type open your command shell (press CTRL+ALT+T) and type in: sudo fdisk -l like on image bellow:


Remeber to do this as super user (root) otherwise you won't be able to see disk partitions. Hence sudo.
The output should be something like on image (depending on your partition tables and devices) 

/dev/sdc1 is the device mapping of usb under my linux distro.
So this output will give you information of device mapping and mine is /dev/sdc1, mapping of your device will be something else perhaps /dev/sd[xa][xb] where [xa] is letter [a-z] number of hd devices on system, and [xb] is a number of partition.

We will need this information, so we can format our flash stick latter on. Now we need to unmount flash usb stick from file system, but before we do that, we should figure out what is the device -> file system mapping of usb. You can find this information by typing sudo mount command via command shell.

$ sudo mount 

Here is the image of output from my system, on yours it will be different but essentially what we need.
if device is mounted onto file system, you will see something like this. 


Once you've found this information (notice you see here mapping of device as well /dev/sdc[x] but if device is not mounted by default we wouldn't know what the mapping is before checking fdisk -l output)

On the image we see that mount path is /media/ddr/bootablefla (essentially it's shorten name of usb stick if name is too long). When you figure out what's the mounted device path, we can unmount device from file system. 

1. Unmount device from file system like so: 

$ sudo umount /media/ddr/bootablefla 

Where after umount you type your own mounted device path. After this step we can format usb stick. 

2. format usb stick. 

To format usb stick, you will need device mapping path and we've found for me it's /dev/sdc1 using fdisk -l command. 

To format usb stick, type command (in command shell) 

$ sudo mkfs.vfat /dev/sdc1

Here is the image of output: 


Note: if you haven't done umount from file system (of usb) error will on output and then you should go back to step 1. 

Just to give you some more options, here are some of other file system types, we've done format using FAT file-system.

mkfs.cramfs   mkfs.ext3     mkfs.ext4dev  mkfs.msdos
mkfs.bfs      mkfs.ext2     mkfs.ext4     mkfs.minix    mkfs.vfat

msdos is FAT32 file system.
ext2,ext3,ext4 linux file systems.
vfat is FAT file system. 
So now you're done with usb flash stick format, now you can make your bootable flash disk. Keep reading.

Other ways to format usb are by using gparted but that won't be covered in this tutorial. 


Creating bootable usb stick using unetbootin

in order to create bootable usb, you'll need one little program called unetbootin. You can download program from here http://unetbootin.sourceforge.net/

When you've downloaded your linux version of unetbootin, you should make it executable by assigning +x permissions to the binary file. (extension is .bin) 

To do this find the path where you've downloaded your unetbootin and execute following command:

$ chmod +x filename (where filename shoud be unetbootin filename ... for me it's unetbootin-linux-608.bin

Now you can start unetbootin using command: 

$ ./unetbootin-linux-608.bin &



You'll be asked for root access (root password and you type in yours) now application will run and it will look like something like this:

Now you should select diskimage iso path, click "..." and select your ISO image you've downloaded earlier. When you select your ISO image path, make sure type is USB DRIVE and Drive is set to your device path (it should auto detect all required fields) then you click "OK". 

After that you'll have to wait for some time until unetbootin copies all the image data to USB stick. Process looks like this: 



You hit exit, and that's it, you have bootable flash stick! 

So when the process finishes, you've done it! That's all there is to it. Now you have a bootable usb flash stick (pen drive) or what ever you call it. To boot from you usb keep reading this tutorial, it will be explained as well (but shortly).

Boot from USB

1. stick in your usb flash stick into usb port. 
2. restart your computer
3. when computer restarts start pressing "ESC" keyboard button (depending on laptop or pc there will be diferent keys most likely ESC, F2, F6, DELETE   

On some laptops pressing ESC gives you possibility to choose booting device for one instance and that's great just select your usb device and hit "ENTER" 

Otherwise you'll have to make a usb flash stick device a priority in BIOS under boot settings. When you do that, remeber to save settings in BIOS. Also don't mess around with other settings. Next time you restart if there is bootable flash stick plugged in, computer will recognize it and start boot process.

That's pretty much it. Hope you find this article / tutorial helpful. Good luck!