• Skip to primary navigation
  • Skip to main content
  • Skip to primary sidebar

DungNQ

Những gì bạn nhìn thấy chỉ là "bề nổi của tảng băng chìm"

  • Trang chủ
  • Giới thiệu
  • Youtube
  • Liên hệ
Home | Đừng bắt chước nhân tài “1000 năm có 1” như Mark Zuckerberg hay Jeff Bezos: Thành công nằm ở 6 điều các “triệu phú nhà bên” đang làm cạnh bạn!

Đừng bắt chước nhân tài “1000 năm có 1” như Mark Zuckerberg hay Jeff Bezos: Thành công nằm ở 6 điều các “triệu phú nhà bên” đang làm cạnh bạn!

Đừng bắt chước nhân tài “1000 năm có 1” như Mark Zuckerberg hay Jeff Bezos: Thành công nằm ở 6 điều các “triệu phú nhà bên” đang làm cạnh bạn!

August 2, 2019 Leave a Comment

Trong vòng 20 năm qua, tôi đã có cơ hội nói trò chuyện với hàng nghìn người thành công. Họ không phải là Mark Zuckerberg hay Jeff Bezos, mà là những người bình thường có thể bạn vẫn gặp hàng ngày, gây dựng sự nghiệp thành công nhờ chính bàn tay mình. Mỗi năm, họ có thể kiếm từ 500.000 USD đến cả triệu USD và tích lũy gấp nhiều lần thế này.

Chúng ta vẫn thường nghe các tỷ phú, thiên tài hàng đầu thế giới chia sẻ câu chuyện thành công của họ và lấy đó làm động lực. Tuy nhiên, hãy nhớ rằng, những bộ óc kiệt xuất như vậy chỉ chiếm 0.01% dân số thế giới. Thay vào đó, bạn nên học tập những “triệu phú nhà bên” – những người thành công đang hiện diện mỗi ngày xung quanh bạn. Đó là cách nhanh nhất và dễ nhất để bạn đạt được những thành tựu cho riêng mình.

Dưới đây là 6 thói quen hàng triệu người thành công ngoài kia vẫn làm mà tôi tích lũy được trong hàng chục năm qua.

Đừng bắt chước nhân tài 1000 năm có 1 như Mark Zuckerberg hay Jeff Bezos: Thành công nằm ở 6 điều các triệu phú nhà bên đang làm cạnh bạn! - Ảnh 1.

Hạn chế sử dụng mạng xã hội

Hầu hết những người thành công tôi gặp đều tránh dùng Facebook, Twitter, Instagram và các loại mạng xã hội khác. Họ cho rằng đó là một sự lãng phí thời gian và sức lực. Chúng chẳng khác nào kẻ cướp thời gian, mà đối với những người thành công, thời gian là vàng bạc. Họ thà sử dụng vốn thời gian ít ỏi của mình để làm ăn thay vì cãi nhau trên Twitter, bình luận dưới ảnh mèo nhà ai đó.

Không dễ dàng hài lòng

Brian Tracy – một chuyên gia về động lực cho biết: “Không mờ mắt vì những lợi ích, tiện nghi trước mắt để đạt được thành tựu lâu dài là điều kiện tiên quyết để thành công”.

Ngày nay, ai cũng muốn đổi xe hơi, cho con học ở đại học danh tiếng, đi nghỉ dưỡng xa hoa, thuê vú em, người làm vườn, gia sư, huấn luyện viên, đầu bếp, mặc quần áo hàng hiệu,… Cứ kiếm được 1 đồng, bạn lại tiêu những 2 đồng; sống như vậy bạn sẽ không thể nào giàu được. Khi bạn tính đến khoản tiền nhà, tiền học, tiền thuế, tiền dành về hưu, bạn sẽ thấy mình thiếu tiền trầm trọng.

Những người thành công luôn biết bỏ cái tôi sang một bên, tránh mâu thuẫn với hàng xóm và sống khiêm nhường hết mức có thể. Điều này giúp họ tiết kiệm được một khoản đáng kể, bởi mục đích lớn nhất của họ là tích lũy tiền, thay vì tiêu chúng. Những đồng tiền này sẽ được họ đầu tư một cách khôn ngoan để tiền lại sinh ra tiền. Càng ổn định về tài chính, bạn sẽ càng tự do sống và làm việc.

Đừng bắt chước nhân tài 1000 năm có 1 như Mark Zuckerberg hay Jeff Bezos: Thành công nằm ở 6 điều các triệu phú nhà bên đang làm cạnh bạn! - Ảnh 2.

Phân bổ thời gian hợp lý

Chỉ cần ngồi xem TV hoặc đọc bình luận trên mạng xã hội một lúc, bạn sẽ ngay lập tức cãi nhau với người khác hoặc cảm thấy bản thân thật tồi tệ. Tuy nhiên, việc “khẩu chiến” trên mạng không chỉ tốn thời gian và năng lượng mà còn tạo thêm kẻ thù cho bạn. Việc xem mọi trận đấu bóng trên TV, chơi game liên tục, đi uống thường xuyên cũng vậy.

Thay vì tiếp tục những thói quen xấu xí không đem lại hiệu quả này, bạn nên dành thời gian đọc sách báo, xem các video trên Youtube có chủ đề giúp ích, hỗ trợ cho cuộc sống và sự nghiệp của bạn. Những người thành công luôn biết rằng, thời gian còn quan trọng hơn tiền bạc. Tiền bạc có thể làm ra, nhưng thời gian không thể lấy lại.

Chăm chỉ và nỗ lực hết mình về lâu dài

Đừng quá lo lắng về chuyện học hành hay sự nghiệp. Bạn phải chủ động kiểm soát tương lai của chính mình. Hãy tìm ra đâu là điểm mạnh, đâu là điều bạn có thể làm để kiếm ra tiền, sau đó hãy nỗ lực hết mình. Có thể bạn sẽ tốn nhiều năm đi sớm về muộn, làm việc cả khi ở nhà lẫn cuối tuần, nhưng cuối cùng bạn sẽ nhận được thành quả tương xứng.

Ai cũng muốn nhanh chóng thành công, nhưng sự thật là những người thành đạt luôn mất nhiều năm làm việc quần quật trước khi leo được tới đỉnh vinh quang. Họ đã phải hy sinh gia đình, bạn bè, những buổi đi xem phim, những sự kiện thể thao trong lúc đó. Đó là cái giá mà bạn bắt buộc phải trả nếu muốn trở thành số 1.

Đừng bắt chước nhân tài 1000 năm có 1 như Mark Zuckerberg hay Jeff Bezos: Thành công nằm ở 6 điều các triệu phú nhà bên đang làm cạnh bạn! - Ảnh 3.

Dám đương đầu với thất bại

Thất bại không phải kẻ thù, mà chính là một người bạn. Chúng ta luôn được dạy phải biết xấu hổ khi thất bại, nhưng điều đó hoàn toàn không đúng. Chỉ bằng cách thử nghiệm và thất bại, bạn mới rút ra bài học quý giá cho mình.

Những người thành công luôn rút ra được bài học bổ ích từ thất bại. Họ thất bại, rút kinh nghiệm rồi cải thiện mình. Việc của bạn là cứ tự tin tiến về phía trước và lờ đi những lời nhận xét tiêu cực sau lưng mình.

Thay đổi tư duy và thái độ

Việc đầu tiên bạn cần làm là dừng mọi suy nghĩ tiêu cực và thay thế chúng bằng những lời lạc quan. Nếu nghĩ mình có thể làm được, bạn sẽ tìm cách để biến điều đó thành hiện thực. Bạn nên hình dung trong đầu mình con người mà bạn muốn trở thành, rồi cố gắng trở thành con người đó. Nếu bạn muốn làm CEO, hãy hành động cho ra dáng một CEO chứ không chỉ là giả vờ. Đây là một việc rất khó bởi cám dỗ sẽ khiến bạn muốn bỏ cuộc. Nhưng nếu theo đuổi đến cùng, bạn sẽ được hưởng quả ngọt xứng đáng về lâu dài.

Ngoài 6 điều cơ bản ở trên ra, những người thành công cũng thường xuyên có những thói quen này:

– Tiếp xúc với những người thông minh, tài giỏi hơn mình

– Sẵn sàng thích nghi với các thay đổi

– Đặt ra mục tiêu và thiết lập hệ thống thói quen để đạt được mục tiêu

– Buông bỏ quá khứ và tập trung cho hiện tại

– Rèn luyện trí tuệ và thể chất

– Tìm ra, chấp nhận và vượt lên trên nỗi sợ của mình

– Luôn lắng nghe và học hỏi từ người khác

– Tận dụng từng phút giây trong cuộc đời này

Hãy thử làm những điều này trong vòng 3 tháng và tôi đảm bảo bạn sẽ thấy điều kỳ diệu xảy ra.

Hiệu chỉnh Google XML Sitemap với trang Sitemap Index

May 13, 2017 Leave a Comment

Tiếp tục chia sẻ các kinh nghiệm của bản thân với hệ thống dữ liệu lớn của WordPress cùng các plugin phổ biến. Google XML Sitemap là plugin không thể thiếu trong bất kỳ hệ thống nào, đây là plugin cung cấp cho webmaster công cụ tuyệt với để cho Google, Bing và các Search Engine khác biết sự tồn tại nội dung của bạn khi phát hành. Tuy nhiên, do giới hạn của việc thiết kế cho blog cỡ nhỏ, các plugin và bản thân WordPress cũng chưa tính hết được các vấn đề gặp phải khi hệ thống có những bài viết lớn dần lên.

Nếu bạn từng biết về SEO, thì sitemap là công cụ quan trọng để bạn cho các Search Engine biết được trong toàn bộ website của bạn có gì, từ đó các con robot, hay gọi là các “con bót” của bộ máy tìm kiếm sẽ căn cứ vào đó để đặt những bước chân đầu tiên khám phá nội dung trên website của bạn. Hôm nay tôi xin chi sẻ cùng các bạn vấn đề thứ 2 tôi gặp phải khi sử dụng Google XML Sitemap, đó là trong Sitemap Index. Vấn để tôi gặp phải là gì? Nếu lượng dữ liệu trên website của bạn đủ lớn, tức là nội dung phát hành trải rộng trong suốt 20 năm chẳng hạn, vậy con số chỉ mục theo từng tháng sẽ là 20 x 12 = 240 trang. Có vẻ không phải là nhiều, nhưng yêu cầu của Google đâu có đơn giản vậy,  nó cần biết thời gian cập nhật gần nhất là khi nào? Cộng thêm một số tiêu chí của Plugin Google XML Sitemap, thì chúng ta phải chạy một câu lệnh như sau

$q = "
          SELECT
            YEAR(p.post_date_gmt) AS `year`,
            MONTH(p.post_date_gmt) AS `month`,
            COUNT(p.ID) AS `numposts`,
            MAX(p.post_modified_gmt) as `last_mod`
          FROM
            {$wpdb->posts} p
          WHERE
            p.post_password = ''
            AND p.post_type = '" . esc_sql($postType) . "'
            AND p.post_status = 'publish'
            $exPostSQL
            $exCatSQL
          GROUP BY
            YEAR(p.post_date_gmt),
            MONTH(p.post_date_gmt)
          ORDER BY
            p.post_date_gmt DESC";

Tất nhiên, nếu như bạn đã đọc bài giới thiệu trước của tôi trong cùng chủ đề, bạn có thể nhận thấy một lỗi tôi đã nói trước đây, sử dụng các hàm trong truy vấn, đây là một điều tối kỵ khi lập trình SQL, nhất là với dữ liệu khổng lồ, ở đây tác giả còn vô cùng hoành tráng, khi sử dụng trong lệnh Group BY… Woa, nếu dữ liệu của tôi là cả triệu bản ghi, chắc tôi phải tính toán lâu lắm, chưa kể có thể ảnh hưởng tới các câu truy vấn khác. Vậy tôi đã sửa lại như thế nào?

//@dungnq optimize start
                                //$posts = $wpdb->get_results($q);
                                /**
                                 * Find min and max post_date_gmt
                                 * Each month to get year, month, numposts, last_mod to add the object array result
                                 * Ignore group by YEAR and MONTH function
                                 */
                                $q = "
          SELECT
            p.post_date_gmt
          FROM
            {$wpdb->posts} p
          WHERE
            p.post_password = ''
            AND p.post_type = '" . esc_sql($postType) . "'
            AND p.post_status = 'publish'
            $exPostSQL
            $exCatSQL
          ORDER BY p.post_date_gmt DESC";                
                                $max_time = $wpdb->get_var($q);
                                
                                $q = "SELECT
            p.post_date_gmt
          FROM
            {$wpdb->posts} p
          WHERE
            p.post_password = ''
            AND p.post_type = '" . esc_sql($postType) . "'
            AND p.post_status = 'publish'
            $exPostSQL
            $exCatSQL
          ORDER BY p.post_date_gmt ASC";                
                                $min_time = $wpdb->get_var($q);
                                
                                $time_min = Datetime::createFromFormat('Y-m-d H:i:s', $min_time);
                                $time_max = Datetime::createFromFormat('Y-m-d H:i:s', $max_time);
                                $time = $time_max;
                                #modify time min to fist time of the month 
                                $time_min = Datetime::createFromFormat('Y-m-d H:i:s', $time_min->format("Y-m-01 00:00:00"));
                                
                                $posts = array();
                                do {
                                    #var_dump($time);
                                    $month = $time->format('m');
                                    $year = $time->format('Y');
                                    
                                    if ($month == 12) {
                                        $next_year = $year+1;
                                        $next_month = '01';
                                    }
                                    else {
                                        $next_year = $year;
                                        $next_month = $month+1;
                                    }
                                    
                                    $q = "
          SELECT
            YEAR(p.post_date_gmt) AS `year`,
            MONTH(p.post_date_gmt) AS `month`,
            COUNT(p.ID) AS `numposts`,
            MAX(p.post_modified_gmt) as `last_mod`
          FROM
            {$wpdb->posts} p
          WHERE
            p.post_password = ''
            AND p.post_type = '" . esc_sql($postType) . "'
            AND p.post_status = 'publish'
                                                AND p.post_date_gmt >= '{$year}-{$month}-01 00:00:00'
                                                AND p.post_date_gmt get_row($q);
                                    #var_dump($result);
                                    if ($post != null && $post->year > 0 && $post->month > 0) {
                                        array_push($posts, $post);
                                    }
                                    #previos month
                                    $time->modify("- 1 month");
                                    
                                }while ($time > $time_min);
                                
                                
                                
                                //@dungnq optimize end

Lý thuyết thì vô cùng đơn giản, với ý tưởng từ bài viết trước, thay vì sử dụng Group By để phân tách dữ liệu theo từng tháng, tôi tìm ngay ra 2 thời điểm, gần nhất và xa nhất, kế đó tôi chạy từng tháng kể từ thời điểm gần nhất, cho tới khi thời điểm xa nhất. Với mỗi vòng lặp, tôi lại tìm ra các thông tin mà hệ thống cần.

Bằng cách trên tôi đã đơn giản hóa một câu lệnh phức tạp, thành một chuỗi các lệnh đơn giản hơn, nhằm để xác định nhanh chóng một vấn đề tránh để các câu truy vấn chạy lâu quá và làm lock lại cả bảng dữ liệu.

Hy vọng với những cách trên, các bạn có thể tự tham khảo để sử dụng, cũng như hạn chế những lỗi gặp phải khi xây dựng hệ thống hay plugin cho cả triệu người dùng.

Hiệu chỉnh Google XML Sitemap Plugin cho website có số lượng bài viết lớn

September 12, 2016 Leave a Comment

Google XML Sitemap là một trong những plugin không thể thiếu của tôi, trước đây khi plugin này chưa hỗ trợ Multisite, tôi đã không sử dụng nó, nhưng rồi tới khi nó hỗ trợ, tôi lại không sử dụng tính năng cho Multisite của nó :D, đúng là ngịch lý của cuộc sống.

Về cơ bản, chức năng của nó không thay đổi nhiều, có một cải tiến lớn đó là việc hỗ trợ Nginx, với cấu hình sau, đây là những gì bạn cần cấu hình thêm khi chạy WordPress cùng Nginx

rewrite ^/sitemap(-+([a-zA-Z0-9_-]+))?\.xml$ "/index.php?xml_sitemap=params=$2" last;
rewrite ^/sitemap(-+([a-zA-Z0-9_-]+))?\.xml\.gz$ "/index.php?xml_sitemap=params=$2;zip=true" last;
rewrite ^/sitemap(-+([a-zA-Z0-9_-]+))?\.html$ "/index.php?xml_sitemap=params=$2;html=true" last;
rewrite ^/sitemap(-+([a-zA-Z0-9_-]+))?\.html.gz$ "/index.php?xml_sitemap=params=$2;html=true;zip=true" last;

Việc cấu hình trên, mục đích để  Rewrite đường dẫn sao cho thật dễ nhớ, không có thì cũng không sao cả, bạn sẽ có một link sitemap với vô số các tham biến ở sau. Tôi sử dụng cho việc không phải nhớ mỗi khi submit website lên Google Webmaster Tool, hay Bing.

Quay về nội dung chính, một plugin tốt như vậy, có hơn 1 triệu lượt download tại sao lại có vấn đề. Trở ngại nằm ở chỗ, khi xây dựng plugin, tác giả chưa tính tới việc dữ liệu sẽ dày lên trong tương lai, vốn là người mong muốn trải nghiệm với hệ thống lớn, tôi luôn sẵn sàng để kiểm tra đâu là plugin tốt, và đối với tôi, đó phải là plugin thiết kế tốt cho tương lai của dữ liệu khổng lồ.

Hai điểm quan trọng Plugin này mắc phải đó là sử dụng truy vấn SQL không tuân thủ nguyên tắc đơn giản.

//Statement to query the actual posts for this post type
      $qs = "
        SELECT
          p.ID,
          p.post_author,
          p.post_status,
          p.post_name,
          p.post_parent,
          p.post_type,
          p.post_date,
          p.post_date_gmt,
          p.post_modified,
          p.post_modified_gmt,
          p.comment_count
        FROM
          {$wpdb->posts} p
        WHERE
          p.post_password = ''
          AND p.post_type = '%s'
          AND p.post_status = 'publish'
          AND YEAR(p.post_date_gmt) = %d
          AND MONTH(p.post_date_gmt) = %d
          {$exPostSQL}
          {$exCatSQL}
        ORDER BY
          p.post_date_gmt DESC
      ";

Bạn thấy đấy, trong truy vấn WHERE tác giả sử dụng hàm YEAR và MONTH để so sánh, mục đích truy vấn này để lọc ra các bài viết có trong cùng một tháng. Tất nhiên bạn có thể thay đổi như sau để có thể giúp hệ thống chạy nhanh hơn, đừng quên comment lại các dòng trên nhé.

// @dungnq optimize start
                        if ($month == 12) {
                            $next_year = $year+1;
                            $next_month = '01';
                        }
                        else {
                            $next_year = $year;
                            $next_month = $month+1;
                        }
                        
                        $qs = "
        SELECT
          p.ID,
          p.post_author,
          p.post_status,
          p.post_name,
          p.post_parent,
          p.post_type,
          p.post_date,
          p.post_date_gmt,
          p.post_modified,
          p.post_modified_gmt,
          p.comment_count
        FROM
          {$wpdb->posts} p
        WHERE
          p.post_password = ''
          AND p.post_type = '%s'
          AND p.post_status = 'publish'
          AND p.post_date_gmt >= '{$year}-{$month}-01 00:00:00'
                                        AND p.post_date_gmt 
Thay đổi ở trên của tôi rất đơn giản, hay vi sử dụng hàm trong câu lệnh điều kiện WHERE tôi xác định luôn một khoảng thời gian nhất định từ là ngày phát hành bài viết phải từ 0 giờ này 1 của tháng, tới trước 0 giờ ngày 1 của tháng kế tiếp, những dòng trên đầu của tôi sử dụng để lấy ra tháng hiện tại và tháng kế tiếp, đặc biệt với tháng 12 thì cần nhảy lên 1 năm.

Còn một điểm lưu ý nữa, nhưng trong tôi nghĩ sẽ chia sẻ cùng các bạn trong tuần tới, nhừng quên ghé tham blog của tôi hàng tuần để nhận được những thông tin  về cách tối ưu WordPress với lượng dữ liệu khổng lồ nhé.

 

Điều chỉnh WordPress Ping

September 5, 2016 Leave a Comment

Nếu bạn là một blogger sử dụng WordPress như một công cụ đề xuất bản những bài viết của mình, thì nội dung này sẽ không hề hợp với bạn. Ở đây tôi đóng vai trò là một người quản trị, sử dụng wordpress cho những hệ thống lớn, có nhiều người truy cập, cũng như số lượng bài viết mỗi ngày được phát hành là không hề nhỏ?

Vấn đề là gì, như những gì bạn có thể đã biết, WordPress cho  một cơ chế ping tới các search engine, nghĩa là sau khi bạn phát hành bài viết, bằng cách này hay cách khác, WordPress sẽ tự động đẩy những nội dung tới các cỗ máy tìm kiếm để thông báo bài viết của bạn tồn tại, hoặc đã được chỉnh sửa.

Thảm họa xảy ra là gì? Nếu 1 ngày bạn chỉ có từ 1 – 2 bài viết, thì không nói, nhưng với một hệ thống lớn, số lượng có thể lên đến 100, 200, thậm chí là 1000 bài viết cần xuất bản mỗi ngày. Tới đây chính là giới hạn của WordPress, hãy thử tưởng tượng, trong một lần xử lý, hệ thống sẽ ping tới Search Engine từ 100 đến 1000 lần, tất nhiên còn phụ thuộc vào tốc độ kết nối, khả năng xử lý của CPU… nhưng cái mà tôi đề cập tới chính là tài nguyên bị giữ lại cho việc xử lý này mới thực là vấn đề, PHP không phải là ngôn ngũ viết tối ưu cho bộ nhớ trong RAM, nên chạy càng lâu, vòng lặp càng lớn thì hệ thống bạn sớm bị cạn kiệt. Hệ quả là, server còi của bạn không còn đủ tài nguyên để phục vụ khách hàng truy cập nữa.

Điều bạn nên làm là gì, hay tìm  đoan code sau trong thư mục wp-include/comment.php, tìm kiếm hàm do_all_pings và thay đổi theo mẫu dưới đây của tôi gợi ý.

/**
 * Perform all pingbacks, enclosures, trackbacks, and send to pingback services.
 *
 * @since 2.1.0
 *
 * @global wpdb $wpdb WordPress database abstraction object.
 */
function do_all_pings() {
  global $wpdb;
  
    $limit = get_option('posts_per_page', 10); // @dungnq get limit of post per page
  // Do pingbacks
  $count=0; // @dungnq count
  while ($ping = $wpdb->get_row("SELECT ID, post_content, meta_id FROM {$wpdb->posts}, {$wpdb->postmeta} WHERE {$wpdb->posts}.ID = {$wpdb->postmeta}.post_id AND {$wpdb->postmeta}.meta_key = '_pingme' LIMIT 1")) {
    delete_metadata_by_mid( 'post', $ping->meta_id );
    pingback( $ping->post_content, $ping->ID );
    $count++; //@dungnq
    if ($count >= $limit) break; // @dungnq
  }

  // Do Enclosures
  $count=0; // @dungnq count
  while ($enclosure = $wpdb->get_row("SELECT ID, post_content, meta_id FROM {$wpdb->posts}, {$wpdb->postmeta} WHERE {$wpdb->posts}.ID = {$wpdb->postmeta}.post_id AND {$wpdb->postmeta}.meta_key = '_encloseme' LIMIT 1")) {
    delete_metadata_by_mid( 'post', $enclosure->meta_id );
    do_enclose( $enclosure->post_content, $enclosure->ID );
    $count++; //@dungnq
    if ($count >= $limit) break; // @dungnq
  }

  // Do Trackbacks
  //$trackbacks = $wpdb->get_col("SELECT ID FROM $wpdb->posts WHERE to_ping  '' AND post_status = 'publish'");
  $trackbacks = $wpdb->get_col("SELECT ID FROM $wpdb->posts WHERE to_ping  '' AND post_status = 'publish' LIMIT $limit");
  if ( is_array($trackbacks) )
    foreach ( $trackbacks as $trackback )
      do_trackbacks($trackback);

  //Do Update Services/Generic Pings
  generic_ping();
}

Thay vì sử dụng vòng lặp vô tận cho tới khi hết các post mới nhất cần ping, tôi chỉnh lại một chút thôi, lấy số giới hạn là số lượng post hiển thị trên trang chủ hoặc feed, sau đó sử dụng bộ đếm để thoát khỏi vòng lặp while.

Tôi đã hoàn toàn giữ lại code của WordPress để bạn tham khảo? Nếu bạn vẫn có suy nghĩ là WordPress chỉ là nền tảng của các blogger, hay tham khảo tờ The Sun nổi tiếng của UK, các kỹ sư đã biết wordpress trở thành một nền tảng cho báo chí vô cùng linh hoạt. Còn sức mạnh của nó đến đâu, tùy bạn kiểm chứng, tôi chỉ có thể chia sẻ rằng, nó nằm trong chính khối óc của bạn, hãy tận dụng thành quả 10+ năm tuyệt vời của những con người xây dựng nên WordPress, đừng biến mình trở thành những nhà khoa học đi phát minh lại những bánh xe.

Google XML Sitemap

September 1, 2016 Leave a Comment

Nếu bạn đã sử dụng wordpress vì bất kỳ một lý do nào đó, bạn đã vô tình sử dụng rất nhiều tiện ích kèm theo của CMS mã mở, mà đối với tôi là tốt nhất trên thế giới hiện nay.

Vơi hệ thống Backend rất thân thiện, tiêu chí đầu tiên của tôi so sánh khi lựa chọn mình nên theo con đường nào Joomla, Zend Framework, hay WordPress. Quả thật là tôi không hề sai lầm khi khám phá cả một cộng đồng lớn với yêu ý tưởng thú vị. Quan trọng hơn, tôi không cần phải mất 6 tháng 1 năm để thử một ý tưởng điên rồ của mình.

Nếu là tay ngang, bạn cũng được thừa hưởng rất nhiều nhưng tính năng ưu việt, mà không có CMS tự phát triển nào có được, khi bạn viết một bài trên hệ thống của mình, WordPress sẽ tự động thông báo với các Search Engine là nội dung của bạn đã tồn tại qua hệ thống ping do chính WordPress phát triển. Tất nhiên bạn sẽ may mắn hơn một cơ số những người ngồi ngoài kia, sử dụng những biện pháp thông thường.

Tuy nhiên, hôm nay tôi cũng muốn giới thiệu cho các bạn một plugin khá thu vị, bổ sung vào những gì chúng ta còn thiếu, đó là Google XML Sitemap, bạn có thể download trực tiếp ở địa chỉ sau

https://wordpress.org/plugins/google-sitemap-generator/

Ping tới Search Engine thôi chưa đủ, cách tốt nhất bạn cần đó là cho Search Engine biết tường tận ngóc ngách ngôi nhà trên internet của bạn, đây là plugin miễn phí mà tôi thấy đáng giá nhất. Những phiên bản trước đây của plugin vốn không hỗ trợ Multisite, tuy nhiên ở phiên bản mới nhất việc này đã được hỗ trợ tối đa.  Plugin này đã ra đời được 9 năm, và hiện nay có trong top những plugin được đánh giá cao nhất.

Tuy nhiên bạn đang ở blog của tôi, nơi bạn có thể tìm thấy các vấn đề khác ngoài việc giới thiệu các tính năng của plugin, tôi sẽ gửi tới các bạn một số vấn đề khác của plugin khi sử dụng với hệ thống có dữ liệu đồ sộ ở những bài sau nhé.

Còn bây giờ, nếu bạn chưa từng sử dụng plugin này, hay khám phá và giúp blog của mình tiến gần hơn với Search Engine nhé.

 

Không nên sử dụng hàm get_page_by_title

August 31, 2016 Leave a Comment

Nếu dữ liệu của bạn đủ lớn, khoảng tầm 500 ngàn đến 1 triệu bản ghi, bạn sẽ thấy hậu quả nhanh chóng từ việc sử dụng hàm này. Việc tiện dụng là không thể phủ nhận, nhưng khi sử dụng hàm trên, sẽ dẫn đến việc so sánh để tìm ra bài viết có post_title phù hợp.

Tuy nhiên, nếu bạn để ý, WordPress sử dụng post_title là text, việc truy vấn dữ liệu text, không hề được index là một thảm hoạ vô cùng lớn. Như trường hợp của tôi, cần so sánh post được gửi thông qua xmlrpc xem đã từng tồn tại trên hệ thống chưa. Rất may, lệnh truy vấn này không thực sự nhiều, và chưa quá ảnh hưởng nghiêm trọng tới hệ thống của tôi.

Tuy nhiên sau khi loại bỏ những dòng lệnh trên, hệ thống trở về điều kiện hoàn toàn bình thường, CPU giảm hẳn đi 1/2, I/O giảm rõ rệt. Vì một phút nhanh chóng làm cho xong plugin của mình theo guilde online, tôi đã phải trả giá cho hiệu năng hệ thống của mình.

 

  • « Go to Previous Page
  • Go to page 1
  • Interim pages omitted …
  • Go to page 55
  • Go to page 56
  • Go to page 57
  • Go to page 58
  • Go to page 59
  • Go to Next Page »

sidebar