Via Flickr:
My second mobile phone ever next to my first mobile phone ever (Motorola Rokr E6).
Adios, my long time amigo. I'll miss you and your little quirks.
Hello, SGS2.
Friday, December 23, 2011
White Samsung Galaxy S2
Sunday, July 03, 2011
uTorrent stuck at 10kBps and with high cpu load
Struggled with a weird scenario today where uTorrent was consuming ~13%CPU and download speed appeared to be capped at 10 kBps. After eliminating the possibility of ISP throttling (Glasnost: Test if your ISP is shaping your traffic), a uTorrent bug (by updating to latest beta), Windows/driver bug (just by restarting Windows) and HDD corruption (rechecked HDD cables; ran CHKDSK /R), I was left with only one thing to try.
The torrent file itself. This was a massive torrent around 60GB in size (let's just say it's "Linux ISO images") but I have downloaded much larger files (a larger collection of said "images") so it did not make sense that it could be the culprit. Besides, the torrent had already downloaded a few gigabytes already. It's only when I restarted uTorrent and the program tried to Hash-check that it started exhibiting this strange behavior.
I tried deleting the torrent data and the torrent's PartFile (~uTorrentPartFile_*.dat) to no avail. Finally, I decided to remove the torrent and opened uTorrent. Success!
So the problem's gone now but I don't have the torrent. But it turned out to be OK because I found what I was looking for as separate torrents.
Epilogue:
Too many times, I encounter the same/similar situations but forget how I solved them. I end up performing the same diagnostic steps I performed during my previous encounter with the problem(with feelings of Deja Vu). This time however, with the help of this anecdotal blog post, I hope to avoid a similar fate the next time uTorrent exhibits these perplexing symptoms. Ciao.
The torrent file itself. This was a massive torrent around 60GB in size (let's just say it's "Linux ISO images") but I have downloaded much larger files (a larger collection of said "images") so it did not make sense that it could be the culprit. Besides, the torrent had already downloaded a few gigabytes already. It's only when I restarted uTorrent and the program tried to Hash-check that it started exhibiting this strange behavior.
I tried deleting the torrent data and the torrent's PartFile (~uTorrentPartFile_*.dat) to no avail. Finally, I decided to remove the torrent and opened uTorrent. Success!
So the problem's gone now but I don't have the torrent. But it turned out to be OK because I found what I was looking for as separate torrents.
Epilogue:
Too many times, I encounter the same/similar situations but forget how I solved them. I end up performing the same diagnostic steps I performed during my previous encounter with the problem(with feelings of Deja Vu). This time however, with the help of this anecdotal blog post, I hope to avoid a similar fate the next time uTorrent exhibits these perplexing symptoms. Ciao.
Tuesday, June 28, 2011
What's It Made Of
I am currently preparing a requirements document for a new in-house web-based project. While looking at various similar websites I needed to know what technologies were being used to develop them.
My methods:
A server's Web Technology is anything from the OS, Web Server, App Server, CDN, etc to the Server's Scripting language, language Framework, CMS, Client-side technologies, etc.
Sometimes, all you need to find is which language the site is coded in. This can usually be decoded from the URL in the address bar (.php, .aspx, .py). But this method becomes harder when the site uses "Clean URLs" or "SEO-friendly" URL scheme which emit webpage addresses without filename extensions or even without filenames. Even here, sometimes, it's possible to look in the anchor tags and form tags to get the "actual" URL with the file extension.
If you need to know the CMS used, you will automatically also find out the language used for the site. For example, if the site uses Wordpress as the CMS, you can be assured that the site is in PHP. Knowing each CMS' naming conventions for variables, files, etc can help here. Actually finding the CMS used in the site can be as easy as looking at the webpage for the CMS's logo or checking the HEAD Meta tags to looking at the element naming conventions in the JS & CSS resource files (Wordpress names start with "wp-") or checking the comments in the HTML/CSS/JS code.
Finding the Framework used in a site can be tricky sometimes because frameworks are meant to be highly customizable and may not contain default code that can be used to identify them. Still, checking the HEAD Meta tags and code comments can be useful and is the first thing I always do.
Identifying the client technologies in use, is of course, trivial since you have the source code right there in your browser. Javascript frameworks like JQuery, MooTools, Yahoo YUI can all be identified easily by looking at the JS files.
Tools:
Some of the information listed above is anyway sent by most of the websites to your browser as HTTP Headers. There are extensions for all major browsers that allow you to see these headers. There are also web-based tools(Web-Sniffer) for this.
Of course, a website may opt not to send these information via the headers and we have to fallback to the old and tedious methods of getting these information.
Quite recently though, I have found an awesome tool that finds out all the information listed above, and more!
To someone like me who used to go through each site's code to get these information, builtwith is like a magical panacea. Another site that I like in similar vein is CMS Detector, which, in spite of its name, detects more than just the CMS used in a website.
In truth though, a website can ask sites like builtwith from displaying its information to the public. In which case, you are back to hacking through the spaghetti code jungle that is the website's code and come up with the answers the old fashioned way.
My methods:
A server's Web Technology is anything from the OS, Web Server, App Server, CDN, etc to the Server's Scripting language, language Framework, CMS, Client-side technologies, etc.
Sometimes, all you need to find is which language the site is coded in. This can usually be decoded from the URL in the address bar (.php, .aspx, .py). But this method becomes harder when the site uses "Clean URLs" or "SEO-friendly" URL scheme which emit webpage addresses without filename extensions or even without filenames. Even here, sometimes, it's possible to look in the anchor tags and form tags to get the "actual" URL with the file extension.
If you need to know the CMS used, you will automatically also find out the language used for the site. For example, if the site uses Wordpress as the CMS, you can be assured that the site is in PHP. Knowing each CMS' naming conventions for variables, files, etc can help here. Actually finding the CMS used in the site can be as easy as looking at the webpage for the CMS's logo or checking the HEAD Meta tags to looking at the element naming conventions in the JS & CSS resource files (Wordpress names start with "wp-") or checking the comments in the HTML/CSS/JS code.
Finding the Framework used in a site can be tricky sometimes because frameworks are meant to be highly customizable and may not contain default code that can be used to identify them. Still, checking the HEAD Meta tags and code comments can be useful and is the first thing I always do.
Identifying the client technologies in use, is of course, trivial since you have the source code right there in your browser. Javascript frameworks like JQuery, MooTools, Yahoo YUI can all be identified easily by looking at the JS files.
Tools:
Some of the information listed above is anyway sent by most of the websites to your browser as HTTP Headers. There are extensions for all major browsers that allow you to see these headers. There are also web-based tools(Web-Sniffer) for this.
Of course, a website may opt not to send these information via the headers and we have to fallback to the old and tedious methods of getting these information.
Quite recently though, I have found an awesome tool that finds out all the information listed above, and more!
To someone like me who used to go through each site's code to get these information, builtwith is like a magical panacea. Another site that I like in similar vein is CMS Detector, which, in spite of its name, detects more than just the CMS used in a website.
In truth though, a website can ask sites like builtwith from displaying its information to the public. In which case, you are back to hacking through the spaghetti code jungle that is the website's code and come up with the answers the old fashioned way.
Monday, June 20, 2011
My first BTC!
Wednesday, May 11, 2011
Ad blocked!
So, I've been working on a project and one of the tasks was to add Advertisement Banner functionality. I used custom php and javascript to create a light-weight Ad display mechanism.
The next part of the project was to add an "AD Rotator" which rotates the displayed Ad every few minutes.
I wrote this class in a separate javascript file included it in the required pages. I almost marked it as completed when I noticed that the rotation script, which was working in localhost, was not working when hosted on the testing server. I was testing in Google Chrome and the Error Console stated:
I was willing to try anything at that point because the project's completion date was near. Time to get debugging. I noticed that my Ad Rotation script was not in the Scripts list box, but present in the "Resources" tab. Hmm... weird, but I didn't think much of it. Next, I tried the Audits tool in Chrome's built-in "Developer Tools". The audit reported that a huge chunk of javascript was not being used. A quick gander at the details revealed that these functions were from the AdBlock plugin that I had installed! *flicker flicker* *flash!*
As the sage Adam Savage once said, "Well, there's your problem!".
After adding an exception to the AdBlock extension, the code works everywhere now. You can rest easy. My lustrous and thick locks are safe, at least for now.
I guess, somehow, when you are the one hosting or displaying Advertisements, you tend not to see them as the annoying, distracting and useless pieces of bandwidth and screen-real estate wasting annoyances of the web that just begs to be blocked!
The next part of the project was to add an "AD Rotator" which rotates the displayed Ad every few minutes.
I wrote this class in a separate javascript file included it in the required pages. I almost marked it as completed when I noticed that the rotation script, which was working in localhost, was not working when hosted on the testing server. I was testing in Google Chrome and the Error Console stated:
I was pulling my hair over this for almost a day. Good 'ol google was not very helpful here. The same page from the testing server ran perfectly in IE! I mean, my code runs in IE not in Chrome?? Has the fabric of space-time begun to unravel? Is it time to deploy the Amber?...Uncaught ReferenceError: start_adRotator is not defined only in chrome
I was willing to try anything at that point because the project's completion date was near. Time to get debugging. I noticed that my Ad Rotation script was not in the Scripts list box, but present in the "Resources" tab. Hmm... weird, but I didn't think much of it. Next, I tried the Audits tool in Chrome's built-in "Developer Tools". The audit reported that a huge chunk of javascript was not being used. A quick gander at the details revealed that these functions were from the AdBlock plugin that I had installed! *flicker flicker* *flash!*
As the sage Adam Savage once said, "Well, there's your problem!".
After adding an exception to the AdBlock extension, the code works everywhere now. You can rest easy. My lustrous and thick locks are safe, at least for now.
I guess, somehow, when you are the one hosting or displaying Advertisements, you tend not to see them as the annoying, distracting and useless pieces of bandwidth and screen-real estate wasting annoyances of the web that just begs to be blocked!
Subscribe to:
Posts (Atom)