Kategoriler


SON YORUMLAR
Tatar Ramazan
Bilgisayar mühendisliğinden şikayet etmeyeyim diyorum ama bütün veriler beni haklı çıkarıyor. Aşağıda yazdık okuyun: Yazılım uzmanı pozisyonu için; 1-) Kariyernette 2000-3000 TL arası maaş veren 100 ilan var. 2-) 3000-6000 arası maş veren 100 ilan 3-) 6000 ve üzeri veren sadece 5 ilan var Bu mu iyi para kazandıran meslek?! Memurluğu iyi ki bırakmamışım. Bir de adamın canını çıkarıyorlar. Her çıkan teknolojiyi öğrenmeni bekliyorlar. İstanbulda kiralar 2000.den başlıyor. 6000 TL bile yüksek maaş falan değil. 2008.de mezun oldum. O zaman da aynı paralar veriliyordu. Zaman geçtikçe aday sayısı artıp rekabet kızıştıkça maaşlar düşüyor, vasatlaşıyor. 2010 yılında 5000 TL kazanan grafikerler duyuyordum. Mesleğimiz yerlerde sürünüyor. Memur olmak ta zorlaşınca uyanık iş veren size iyi para verir mi sanıyorsunuz? Nasıl olsa kaçamazsınız Devlet.e...KPSS zor artık.

yeşekkür ederiz beğendim
Dilara
Merhaba, ben bilgisayar mühendisliği öğrencisiyim yabancı dilimde var ama sitelerden okuduğum yorumlardan dolayı gelecek kaygısı yaşıyorum,nasıl bir yol izlemem gerek lütfen yorumlarınızla bana yardımcı olur musunuz?
sultan b.
makaleniz gerçekten yardımcı ve aydınlatıcı fakat örnekler verirken sürekli .abi, adam. vs özneler kullanmanız beni rahatsız etti. bilgisayar mühendisi olmak isteyen bir kadın olarak açıkçası bu durum beni biraz umutsuzluğa sürüklemedi de değil.
irfan
https://www.udemy.com/linux-and-bash-shell-scripting-from-beginner-to-intermediate/learn/v4/overview
Tatar Ramazan
İlerde düzelecek inşaallahu Teala her şey. Herkes hakkını eninde sonunda alır. Son gülen iyi güler. Başlangıçta bütün mühendisler aynı alır ama kendini geliştiren ilerleyen dönemlerde farkı açar.
tatar ramazan-a
tatar ramazan ağlamayı bırak. kendi şirketini kurma vaktin gelmiş. devletten ayrıl. işveren ol artık. herkesi eleştirmeyi bırak. eleştirilmeyecek bir şirket kur.
bir zamanlar anadoluda
zamanında iyi sürünmüş, iyi aşağılanmış ve itlerin çakalların arasında yaşamış, onlarla savaşmış itliği çakallığı halen öğrenen birisi olarak tavsiyeler: 1- kendini geliştirmek tam bir saçmalıktır (Google vb. mülakatlara falan girmek gibi durumlar hariç) 2- herşey çevrenle başlar çevrenle biter, iş bulma da karı da kız da çevrene bakar. başta suratıma bile bakmayan kızlar, popülerlğimi (milletçe akıllı, çalışkan, başarılı, zengin, cool diye nitelenmek gibi) görünce köpeğim oldu selam dahi vermiyorum yine rahat vermiyorlar. 3- nasıl populer oldum? çalışarak mı? en az çalışanlardandım. 4- algıyı yöneteceksiniz. kendinizi satmayı bileceksiniz. reklamınızı yapacaksınız. kendini satamazsanız ne kız gelir ne iş verirler. 5- o beğenmediğin 3 birimlik erkek veya işe giren eleman, potansiyeli 1 ise 3 gösterir sen 10 ken bişr gösteremezsen, ne karı gelir ne birşey. yarın karın da sygı duymaz gözünün önünde başkasıyla sikişir.
Tatar Ramazan
Site sahibine 2008 de mail atmıştım danışmıştım. O günden beri siteyi takip ederim. Ateşli yazıları kendimi geliştirmemde etkili olmuştur. İstanbul üniversitesi iyi eğitim veriyor diye yorum yazan da bendim. Çok uyanığımdır. Zekam keskindir. Keşke üniversitem de biraz yol gösterseydi. Dersler, kitaplar belli sen niye hocalardan rehberlik bekledin diyecek olursanız: Tamam da bir sürü programlama dili var. Hangisinden başlayacağım, ne bileyim? C dilini öğrenin sonra C# veya java dan devam edersiniz diyebilirlerdi. Bunu bile yapamadılar. Bölüm başkanı da değişmişti. İyi şeyler yapayım derken daha kötü batırdı. Nesne tabanlı programlama dersinde for döngüsü gördük C sharpta. En azından takip programı yaptırdı bize işte. ADO.NET, SQL Server öğrendik. Ama sınıf nesne tabanlı programlamayı bir türlü sökemedi. Çünkü C dilinde struct konusunu öğrenmeyince sınıfları da özümsemek zor oldu. Debelendik durduk. İTÜ, Yıldız Teknik, İstanbul gibi üniversitelerin farkı burda. Bu kadar basit! C, C++ dilini iyi veriyor adamlar. Yahu C dilinin konularını tahtaya yazsaydı araştırma görevlisi bana yeterdi bile. Mıy mıy mıy yapıp durdular 4 sene boyunca. Ben ilk yarıyıl tatilinde (5 haftaydı) evde İntegraldan 200 soru çözüp vize finalden 100-100 almış adamım. Görün işte ben bile geri kalıyorsam programcılıkta öğretimde sorun var demek ki. Site sahibine kalsa üniversite önemli değil. Tabi kendisi İstanbul üniversitesinde iyi eğitim aldı. Kötü öğretimi, ilgisizliği tatmadı.
Tatar Ramazan
Eve şanssızdım her açıdan bundan sonra mutlu olur muyum bilmiyorum. Biz imanlıyız umudumuzu kesmeyiz. Yazdıklarımda doğruluk payı da var ama. Meslek ve sektörde bir sürü sıkıntı var. Sektör yöneticileri ve Üniv. hocaları niye bir araya gelip sorunları çözemiyor. Bilişim sektörü daha verimli büyük olabilirdi. Yazılım çağı diyorsak bu işe bir el atmalıyız. Mesleğimden şikayet ederim ama aynı zamanda ateşli gayretli adamımdır. Üniversitede gene hasta takip programı, satranç oyunu, E-Ticaret sitesi ve irili ufaklı 30 tane program yapmıştım. Çok boş mezun olmadım. Sınıfın ineklerindendim. Marmara bölgesinde 92 den sonra kurulan bir üniversitede okudum. Hocalar ilgisiz ve bilgisizdi. Sınıfın % 70 i C dilini öğrenemeden mezun oldu. Şunu şöyle yapın demekten aciz adamları hoca diye başımıza niye koyuyorlar? Sistemde de saçmalık var. Derslerin çoğu işe yaramıyor. Lise 1 den itibaren programlama çalışsaydım şimdi çok farklı olurdu. Boş yere zaman kaybı okumak. İnsanlara da zulmetmeyin gayrı. Bilim adamı olmak isteyen üniversitede kalsın. Bana Java, .NET, Oracle lazım kardeşim. Okumayanların eşi, arabası var. Ben sürünüp duruyorum. Memur maaşıyla bi şey yapamıyorsun ki. 2 ay önce 5000 tl oldu işte. Harita mühendisine de veriyorlar o kadar zaten. Benim sadece SQL bilgim onları ezmeye yeter.
HARUN AYDIN
YAZI BENİ DE ETKİLEDİ.BENDE BİLGİSAYAR ALANINDA İLERLEMEK İSTİYORUM.İLGİM DE VAR AMA YETERLİ BİLGİM YOK.BU YAZIDA ANLADIM Kİ GEREK DE YOKMUŞ İYİ BİR OKULDAYIM İYİ BİR ÜNİVERSİTE DE KAZANMAK İÇİN ELİMDEN GELENİ YAPICAM. BU YAZI İÇİN ÇOK TEŞEKKÜR EDERİM..
Mehmet Cemil Bayhan
Çok harika bir makale yazmışsınız.Ellerinize sağlık. Beni bayağı gaza getirdi gerçekten. Ben şuan lise 3 öğrencisiyim. Şimdiden bilgisayar hakkında bilgi sahibi olmaya çalışıyordum ama sizin bu yazınızı okuduktan sonra fikrim değişti. Artık şuan düşüneceğim tek şey YGS-LYS. SİZE NE KADAR TEŞEKKÜR ETSEM AZDIR. ÇOOOOOK TEŞEKKÜR EDİYORUM.........😆😉😊
Mehmet Cemil Bayhan
Çok harika bir makale yazmışsın ızgara.Ellerinize sağlık. Beni bayağı gaza getirdi gerçekten. Ben şuan lise 3 öğrencisiyim. Şimdiden bilgisayar hakkında bilgi sahibi olmaya çalışıyordum ama sizin bu yazınızı okuduktan sonra fikrim değişti. Artık şuan düşüneceğim tek şey YGS-LYS. SİZE NE KADAR TEŞEKKÜR ETSEM AZDIR. ÇOOOOOK TEŞEKKÜR EDİYORUM.........😆😉😊
eskidevir-yenidevir
sizin şanssızlığınız olmuş. işler yolunda gitmemiş diye anlıyorum.

Bilgisayar Mühendisleri
Here is the website inspired me to use 
it as a guide when I tried to define 
myself as an engineer candidate a few 
years ago. It really helped me to work
 and study feeling in confidence with 
being on the right way. I suggest this 
website to whom it may direct her/his 
to find the right career path. It 
includes many articles varies from 
real life experiences to detailed 
software engineering issues. But the 
most dignified parts for me are the 
articles in general and career titles.
Son okunan makaleler:
Oracle - SQL Trace ve TKPROF nedir, nasıl kullanılır?
PHP Geliştirme Ortamı - Zend Studio
Bilgisayar Mühendisliği Hakkındaki 10 Büyük Yalan!
Windows Workflow Foundation State Machine
Dünya Genelinde İnsanları Üç gruba Ayırıyorlar
İTURO 2008 Microsoft Robotics Studio Finalisti Üniversiteler
Sanal Bellek Nedir?
Vakıf üniversiteleri
BİLGİSAYAR MÜHENDİSLİĞİ GEREKSİZ BİR MESLEKTİR !!!
Akıllı istemciler oluşturabilmek için ClickOnce
Bilgisayar Mühendisliğini yeni kazandım, neler yapmalıyım?
MODEM ÇEŞİTLERİ
NHibernate için Veri Erişim Katmanını Otomatik Oluşturma
Bilgisayar Mühendisliği ÖSS Taban Puanları 2009
Neden yazılım uzmanı olamayacağınızın 10 kanıtı?
Microsoftda Çalışan Bir Türk ile Yapılmış Röportaj
Online Java Dersleri - İstisnalar - Exceptions
2008 CPU TURKEY YARIŞMASI SONUÇLANDI!
Kendini Geliştirmek Ne Demek?
Askerlik ve Bilgisayar Mühendisliği

Bilgisayar Mühendisleri Portalı

Oracle - SQL Trace ve TKPROF nedir, nasıl kullanılır?

Veritabanı seviyesinde, yazılan kod ya da kod parçasında bir yavaşlık, performans düşüklüğü varsa bunun nedenini araştırmak gerekir.Bunu yapabilmenin en iyi yolu da “SQL Trace” almaktır.Peki nedir SQL Trace?

SQL Trace istenilen bir andan yine istenilen bir ana kadar olan zaman dilimi içersinde session ya da veritabanı seviyesinde gerçekleşen tüm olayların CPU da harcanan zaman, parse-execute-fetch aşamalarında gecen süre ve adet bilgileri , I/O miktarı gibi SQL in performansı ile direk alakalı bilgilerin okunabildiği ortamdır.TKPROF ta alınan bu SQL Trace’in okunabilirliğini arttırmaya yönelik Oracle ın bir ürünüdür.Öncelikle veritabanının trace dosyalarını nereye attığını tespit etmek gerekir. 

select value from v$parameter where name = ‘user_dump_dest’

ile dosyaların atıldıgı dizin bilgisini alabiliriz.

NOT : ”USER_DUMP_DEST” bir init.ora parametresidir.SESSION bazında değil ama SYSTEM seviyesinde aşağıdaki komutla değiştirilebilir :
            alter system set user_dump_dest=”d:sqltrace”;

SQL Trace dosyaları session bazlıdır, “kullanıcı(user)” bazlı değildir.Aşağıdaki script ile veritabanında bulunan kullanıcılara ait trace dosyaları bulunabilir :

select b.username, c.value || ‘\’ || lower(d.value) || ‘_ora_’ ||
       to_char(a.spid, ‘fm00000′) || ‘.trc’ “TRACE_FILE”,
       a.pid PID, b.serial#  session_number
from v$process a, v$session b, v$parameter c, v$parameter d
where a.addr   = b.paddr
and c.name     = ‘user_dump_dest’
and d.name     = ‘db_name’
and b.username is not null;

Burada dikkat edilmesi gerek bir başka nokta da oluşan trace dosyalarının isimlendirme yöntemidir.Örneğin yukardaki sorguda “_ora_” gibi bir formatlama yapıldı.9.x ve yukarısında bu şeklidedir.Aşağıda örnekler verilmiştir :

Version     Isimlendirme şablonu    Örnek
 
7.3.4         snnn_pid.trc                      s000_1234.trc
8.0.5         ora_pid_trc                       ora_1234.trc
8.1.7         ora_pid_instance.trc          ora_1234_INSTNC1.trc
9.x-10g.x   instance_ora_pid.trc          INSTNC1_ora_1357.trc

Şimdi de SQL Trace ‘i “session” bazında  alabilmek için yapılması gereken adımlara bakalım :

1) CPU da harcanan zaman, bekleme süreleri gibi bilgileri alabilmek için :alter session set timed_statistics = true;

2) SQL Trace i kullanabilmek için :
alter session set sql_trace = true;

NOT : Aynı işlem DBMS_SESSION.SET_SQL_TRACE(TRUE); ile de yapılabilir.

NOT : Bir DBA başka bir session içinde bu özelliği aktif edebilir.Bunun içinDBMS_SYSTEM.SET_SQL_TRACE_IN_SESSION(sid,serial#,sql_trace true/false);kullanılır.

Uygun ”sid” ve “serial#” degerleri ilgili kullanıcı için v$session tablosundan alınabilir.

3) Trace dosyasının boyutunu sınırsıza cekmek iyi olabilir :
alter session set max_dump_file_size =unlimited;

4) Her seviye de istatistik alabilmek için :
alter session set statistics_level = all ;

5) Oluşacak dosyanın adına okunabilirlik amacıyla eklenti yapmak için :
alter session set tracefile_identifier = ‘user_sql_trace’;

Örneğin normalde “xe_ora_3584.trc” adında olşacak olan dosya “xe_ora_3584_user_sql_trace.trc” adı ile oluşacaktır.

6) “wait events” bilgilerinin trace dosyasına yazıldıgından emin olmak için :alter session set events ‘10046 TRACE NAME CONTEXT FOREVER, LEVEL 8′;

7) Trace alacağımız kod çalıştırılır.(SQL , PL/SQL …) 8) Istediğimiz kod çalıştıktan sonra trace almayı durdurmak için :
alter session set sql_trace = false;NOT : işlem DBMS_SESSION.SET_SQL_TRACE(FALSE); ile de yapılabilir.     

alter session set events ‘10046 TRACE NAME CONTEXT OFF’;

NOT: Yeterli miktar veri toplandığından emin olunduğunda trace özelliği kapatılmalıdır.Yoksa dosya şişer, diskte yer problemleri başlayabilir.Bu işlemler sonucunda “USER_DUMP_DEST” dizini altında “xxxuser_sql_trace.trc” adlı dosya oluşur.Ancak bu dosya okunabilirlik anlamında sıkıntı olan bir dosya.

Okunabilirliği arttırmak amacıyla Oracle “TKPROF” eklentisi yapmıştır.İşletim sisteminde “command prompt“ ta örneğin aşağıdaki gibi (Windows ta):tkprof ..\UDUMP\xe_ora_3060_user_sql_trace .trc D:\ sql_trace.txt explain=test/test sys=yes waits= yesşeklinde olabilir.

“UDUMP\xe_ora_3060_user_sql_trace .trc”  - - > oluşan trace dosyası
“D:\ sql_trace.txt”                                     - - > oluşacak yeni dosya adı
“explain=test/test sys=yes waits= yes”       - - > TKPROF parametreleriPek çok TKPROF parametresi ve kullanımı var.Ihtiyaca göre set edilebilir.
Detay bilgiyi aşağıdaki linkten bulabilirsiniz :
http://download-uk.oracle.com/docs/cd/B19306_01/server.102/b14211/sqltrace.htmOluşan
 

trace dosyası örneğin aşağıdaki gibi olacaktır :
…………………..
PARSING IN CURSOR #8 len=41 dep=0 uid=0 oct=3 lid=0 tim=19068624436 hv=253931300 ad=’1d337414′
select * from ttest where object_id = 123
END OF STMT
PARSE #8:c=0,e=47,p=0,cr=0,cu=0,mis=0,r=0,dep=0,og=1,tim=19068624429
EXEC #8:c=0,e=79,p=0,cr=0,cu=0,mis=0,r=0,dep=0,og=1,tim=19068682136
WAIT #8: nam=’SQL*Net message to client’ ela= 9 driver id=1111838976 #bytes=1 p3=0 obj#=-1 tim=19068691291
FETCH #8:c=0,e=89,p=0,cr=3,cu=0,mis=0,r=1,dep=0,og=1,tim=19068700670
WAIT #8: nam=’SQL*Net message from client’ ela= 269 driver id=1111838976 #bytes=1 p3=0 obj#=-1 tim=19068710270
FETCH #8:c=0,e=57,p=0,cr=1,cu=0,mis=0,r=0,dep=0,og=1,tim=19068720765
WAIT #8: nam=’SQL*Net message to client’ ela= 10 driver id=1111838976 #bytes=1 p3=0 obj#=-1 tim=19068759424
WAIT #8: nam=’SQL*Net message from client’ ela= 347 driver id=1111838976 #bytes=1 p3=0 obj#=-1 tim=19068769859
*** SESSION ID:(25.70) 2007-01-22 15:39:16.740
STAT #8 id=1 cnt=1 pid=0 pos=1 obj=14673 op=’TABLE ACCESS BY INDEX ROWID TTEST (cr=4 pr=0 pw=0 time=127 us)’
STAT #8 id=2 cnt=1 pid=1 pos=1 obj=14674 op=’INDEX RANGE SCAN TTEST_ID_IDX (cr=3 pr=0 pw=0 time=92 us)’
WAIT #0: nam=’SQL*Net message to client’ ela= 7 driver id=1111838976 #bytes=1 p3=0 obj#=-1 tim=19068811087
WAIT #0: nam=’SQL*Net message from client’ ela= 335 driver id=1111838976 #bytes=1 p3=0 obj#=-1 tim=19068821991
=====================
PARSING IN CURSOR #1 len=45 dep=0 uid=0 oct=7 lid=0 tim=19068832275 hv=349105966 ad=’1d0ef7cc’
DELETE FROM PLAN_TABLE WHERE STATEMENT_ID=:1
END OF STMT
PARSE #1:c=0,e=53,p=0,cr=0,cu=0,mis=0,r=0,dep=0,og=1,tim=19068832269
EXEC #1:c=0,e=181,p=0,cr=3,cu=0,mis=0,r=0,dep=0,og=1,tim=19068887749
WAIT #1: nam=’SQL*Net message to client’ ela= 8 driver id=1111838976 #bytes=1 p3=0 obj#=-1 tim=19068898228
WAIT #1: nam=’SQL*Net message from client’ ela= 145 driver id=1111838976 #bytes=1 p3=0 obj#=-1 tim=19068908629
STAT #1 id=1 cnt=0 pid=0 pos=1 obj=0 op=’DELETE  PLAN_TABLE$ (cr=3 pr=0 pw=0 time=106 us)’
STAT #1 id=2 cnt=0 pid=1 pos=1 obj=8655 op=’TABLE ACCESS FULL PLAN_TABLE$ (cr=3 pr=0 pw=0 time=96 us)’
…………………..

TKPROF kullandıktan sonra olusan dosya içeriği ise aşağıdaki gibi olacaktır :
…………………..
EXPLAIN PLAN SET STATEMENT_ID=’PLUS4294967295′ FOR select * from ttest where
  object_id = 123
call        count       cpu    elapsed       disk      query    current    rows
——- ——  ——– ———- ———- ———- ———-  ———-
Parse        2          0.00       0.00          0          0          0           0
Execute     2          0.03       0.20          0          0          0           0
Fetch        0           0.00       0.00          0          0          0           0
——- ——  ——– ———- ———- ———- ———-  ———-
total         4            0.03       0.20          0          0          0           0
 

 Hakkı Oktay
http://hakkioktay.wordpress.com

Bu makaleyi beğendin mi? Yorumunu Yaz!







Sizden Gelen Yorumlar:

Yorum Yazın

erol(09.01.2009 11:40:03)
Çok güzel açıklanmış. Türkçe olması ayrıca güzel.
%50 %25 %25
Katılıyorum Çekimserim Katılmıyorum






Copyright© 2001-2017. Bilgisayar Mühendisleri Portalı | Bütün hakları saklıdır.